首页 > 编程语言 >JavaScript第三讲:解锁JavaScript的数据世界:基本数据类型与类型转换的奥秘

JavaScript第三讲:解锁JavaScript的数据世界:基本数据类型与类型转换的奥秘

时间:2024-06-03 13:29:40浏览次数:27  
标签:类型转换 console log JavaScript 数据类型 let 字符串

前言:

hello,大家好,在JavaScript的编程世界中,数据是构成一切的基础。无论是构建复杂的Web应用,还是处理用户输入,我们都无法绕开数据这一核心元素。而在JavaScript中,数据以不同的形式存在,我们称之为数据类型。理解这些数据类型以及它们之间的转换关系,对于编写高效、健壮的代码至关重要。今天星途将带你走进JavaScript的数据世界,深入解析基本数据类型以及类型转换的奥秘。

 

JavaScript基本数据类型详解

在JavaScript中,基本数据类型是编程的基础。它们是不可变的,即一旦赋值后就不能再改变其类型。下面我们将从几个方面来详细介绍JavaScript的基本数据类型。

1. 声明了但未赋值

当你声明一个变量但没有给它赋值时,它的值将是undefined

let variable;  
console.log(variable); // 输出: undefined

2. 布尔(Boolean)

布尔类型只有两个值:truefalse

let isTrue = true;  
let isFalse = false;  
console.log(isTrue); // 输出: true  
console.log(isFalse); // 输出: false

3. 数字(Number)

JavaScript中的数字类型可以是整数或浮点数。

let integer = 42;  
let floatNumber = 3.14;  
console.log(integer); // 输出: 42  
console.log(floatNumber); // 输出: 3.14
JavaScript还有一个特殊的数字值NaN(Not a Number),表示非数字值。
let notANumber = NaN;  
console.log(notANumber); // 输出: NaN

4. 字符串(String)

字符串是由字符组成的文本。在JavaScript中,字符串必须用引号(单引号或双引号)括起来。

let greeting = "Hello, World!";  
console.log(greeting); // 输出: Hello, World!

5. 动态类型

JavaScript是一种动态类型语言,这意味着你可以在程序运行过程中改变变量的类型。

let dynamicVar = 5; // 数字类型  
dynamicVar = "Hello"; // 字符串类型  
console.log(dynamicVar); // 输出: Hello

6. 变量类型判断

你可以使用typeof运算符来检查一个变量的类型。

let num = 10;  
let str = "Hello";  
let bool = true;  
  
console.log(typeof num); // 输出: number  
console.log(typeof str); // 输出: string  
console.log(typeof bool); // 输出: boolean  
console.log(typeof undefinedVar); // 假设undefinedVar未声明,输出: undefined

注意:对于nulltypeof返回的是"object",这是JavaScript的一个历史遗留问题。

let nullVar = null;  
console.log(typeof nullVar); // 输出: object(但null实际上是特殊的值,不是对象)

7. 空对象/对象不存在

在JavaScript中,如果你尝试访问一个不存在的对象属性或数组元素,你通常会得到一个undefined。但是,如果你尝试访问一个未定义的变量的属性或方法,你会得到一个错误(如ReferenceError)。

let obj;  
console.log(obj.property); // 输出: undefined(不会抛出错误)  
  
let nonExistentVar;  
console.log(nonExistentVar.property); // 抛出 ReferenceError: nonExistentVar is not defined

如果你尝试访问一个空对象的属性,它也会返回undefined,但不会抛出错误。

let emptyObj = {};  
console.log(emptyObj.nonExistentProperty); // 输出: undefined(不会抛出错误)

 

JavaScript 类型转换详解

在JavaScript中,类型转换(Type Coercion)是一个重要的概念,它指的是将一种数据类型的值转换为另一种数据类型的值。下面我们将从几个方面来详细讲解JavaScript中的类型转换。

1. 伪对象(Primitive Wrappers)

JavaScript有三种基本数据类型的伪对象:BooleanNumberString。当你尝试在一个基本类型的值上调用一个方法时,JavaScript会临时将其转换为对应的对象。但这种转换是暂时的,只在调用方法时有效。

let str = "hello";  
let charCode = str.charCodeAt(0); // 这里"str"被临时转换为String对象  
console.log(charCode); // 输出: 104 (ASCII码对应'h')

2. 转换为字符串

JavaScript有多种方式可以将值转换为字符串。

  • 使用toString()方法(适用于nullundefined之外的所有值)。

  • 使用String构造函数(与toString()相似,但会尝试将非字符串值转换为字符串)。

  • 使用模板字符串或字符串连接(通过+操作符)。

let num = 123;  
let str1 = num.toString(); // 使用toString()  
let str2 = String(num); // 使用String构造函数  
let str3 = num + ""; // 使用字符串连接  
console.log(str1, str2, str3); // 输出: "123" "123" "123"

3. 数字转字符串

特别地,将数字转换为字符串时,通常使用toString()方法或String()构造函数。它们都会将数字转换为字符串,但toString()方法允许你指定基数(如二进制、八进制、十六进制等)。

let hexStr = (255).toString(16); // 使用基数16(十六进制)  
console.log(hexStr); // 输出: "ff"

4. 转换为数字

JavaScript提供了几种将值转换为数字的方法。

  • 使用Number()构造函数。
  • 使用parseInt()parseFloat()函数。
  • 使用一元加号运算符+

注意:parseInt()parseFloat()会尝试从字符串的开头解析一个整数或浮点数,如果字符串以非数字字符开头,则返回NaN

let num1 = Number("123"); // 使用Number()  
let num2 = parseInt("123abc"); // 使用parseInt(),结果为123  
let num3 = parseFloat("123.45abc"); // 使用parseFloat(),结果为123.45  
let num4 = +"123"; // 使用一元加号运算符,结果为123  
console.log(num1, num2, num3, num4); // 输出: 123 123 123.45 123

5. 转换为Boolean

在JavaScript中,当值被用作布尔上下文(如条件语句)时,它会被自动转换为布尔值。以下是JavaScript中的“假值”(falsy values):

  • false
  • 0(包括-0
  • ""(空字符串)
  • null
  • undefined
  • NaN

所有其他的值都是“真值”(truthy values)。

let bool1 = Boolean(0); // 假值转换为false  
let bool2 = Boolean("hello"); // 真值转换为true  
console.log(bool1, bool2); // 输出: false truelet bool1 = Boolean(0); // 假值转换为false  
let bool2 = Boolean("hello"); // 真值转换为true  
console.log(bool1, bool2); // 输出: false true

6. Number()和parseInt()的区别

  • Number()尝试将整个字符串解析为一个数字(整数或浮点数),如果无法解析则返回NaN
  • parseInt()尝试从字符串的开头解析一个整数,如果无法解析则返回NaN(在ES5及更早版本中返回NaNundefined)。它还会接受一个可选的基数参数。

7. String()和toString()的区别

  • String()是一个构造函数,它可以用于将任何值转换为字符串。
  • toString()是一个方法,定义在Object.prototype上,因此几乎所有对象都继承了它。但是,某些对象(如nullundefined)没有toString()方法。如果自定义对象没有定义toString()方法,则调用时会返回[object Object]

 

在JavaScript的编程旅程中,掌握基本数据类型和类型转换的知识就像拥有了打开数据世界的钥匙。它们不仅能帮助我们更好地理解代码的执行逻辑,还能让我们在处理数据时更加得心应手。希望通过本文的介绍,你能对JavaScript的基本数据类型和类型转换有更深入的认识,并在实际的编程中灵活运用。让我们一起在JavaScript的数据世界中畅游,探索更多的编程奥秘吧!

 

标签:类型转换,console,log,JavaScript,数据类型,let,字符串
From: https://blog.csdn.net/2303_80856850/article/details/139354870

相关文章

  • C++:特殊类设计和四种类型转换
    一、特殊类设计1.1不能被拷贝的类     拷贝只会放生在两个场景中:拷贝构造函数以及赋值运算符重载,因此想要让一个类禁止拷贝,只需让该类不能调用拷贝构造函数以及赋值运算符重载即可。C++98:1、将拷贝构造函数与赋值运算符重载只声明不定义。(防自己人)    ......
  • JavaScript 事件循环竟还能这样玩!
    JavaScript是一种单线程的编程语言,这意味着它一次只能执行一个任务。为了能够处理异步操作,JavaScript使用了一种称为事件循环(EventLoop)的机制。本文将深入探讨事件循环的工作原理,并展示如何基于这一原理实现一个更为准确的setTimeout、setInterval什么是事件循环?事件循环是......
  • c语言基本概念和数据类型常见问题
    1.两种特殊的转义字符:\ddd和\xdd是什么?• \ddd :ddd表⽰1~3个⼋进制的数字。如: \130表⽰字符X• \xdd :dd表⽰2个⼗六进制数字。如:\x30表⽰字符02.指出里面哪些是转义字符,并给出运行结果printf("%zd\n",strlen("c:\\test\128\abcd.c"));转义字符有: \\ , \1......
  • 大学生HTML期末大作业——HTML+CSS+JavaScript公司网站(自行车)
    HTML+CSS+JS【公司网站】网页设计期末课程大作业web前端开发技术web课程设计网页规划与设计......
  • javaScript基础一
    javaScript系列文章目录文章目录系列文章目录前言一、<script>元素二、语言基础1.1.区分大小写1.2.读入数据1.3注释1.4严格模式(strictmode)三、变量四、数据类型总结前言本文将简单的讲解JavaScript的基础预备知识一、<script>元素将JavaScript插入HTML的主要......
  • TS-类型转换(显式)
    1.将其他类型转换为布尔类型要将其他类型转换为布尔类型,只需要将待转换的值传入Boolean()函数varmsg:string="ok";varmsgToBollean:boolean=Boolean(msg);//得到trueBoolean()函数会判断传入的值是空值还是非空值。若表示非空值,则返回true若表示空值,则返回fals......
  • MySql 数据类型选择与优化
    选择优化的数据类型更小的通常更好一般情况下尽量使用可以正确存储数据的最小类型。更小的数据类型通常更快,因为它们占用更少的磁盘,内存和CPU缓存,并且处理时需要的CPU周期也更少。但也要确保没有低估需要存储值的范围。简单就好简单的数据类型通常需要更少的CPU周期。......
  • 第2章 变量和简单数据类型
            在本章中,你将学习可在Python程序中使用的各种数据,还将学习如何将数据存储到变量中,以及如何在程序中使用这些变量。2.1运行hello_world.py时发生的情况        运行hello_world.py时,Python都做了些什么呢?下面来深入研究一下。实际上,即便是运行简单......
  • 【JavaScript脚本宇宙】从i18next到Date-fns:国际化和本地化库
    跨越JavaScript新境界:六大库全面评测前言本文将详细介绍六种具有不同功能的JavaScript库,包括处理多语言支持、全球化和本地化、格式化日期、数字和字符串,解析、验证、操作、显示日期和时间,格式化和操作数字,以及最全面、最简单和一致的工具集用于处理JavaScript中的日期等......
  • HTML期末学生大作业-基于班级校园我的校园网页设计与实现html+css+javascript
    ......