一、强制类型转换
强制类型转换是指将一种数据类型转
换为另一种数据类型
的过程。在JavaScript中,这种转换可以是显式
(调用转换函数)的或隐式
的
基本类型转换
主要涉及三种基本类型:字符串、数字和布尔值
转换为字符串
将值转换为字符串有多种方式,其中最常见的是通过调用String()函数
或使用加号运算符(+)与空字符串
相加 或者ES6的模板字符串 ‘ `` ’ 。
let num = 123;
let str = String(num);
let str2 = num + '';
console.log(str);
console.log(str2);
转换为数字
将值转换为数字也有多种方式,可以使用Number()函数、加号运算符(+)、乘号运算符 *、parseInt()或parseFloat()等
let str = "456";
let num = Number(str);
let num2 = +str;
console.log(num);
console.log(num2);
parseInt
()和parseFloat()
用于解析字符串中的数字
,但它们与Number()
有所不同,因为它们不会处理非数值字符并且可以解析带有小数点的字符串
。
let str = "3.14";
console.log(parseInt(str));
console.log(parseFloat(str));
转换为布尔值
所有值在JavaScript中都可以转换为布尔值
。JavaScript中有一些被认为是假值
的值,它们转换为布尔值时会得到false
,包括:0、-0、null、undefined、NaN和空字符串("")
。其他所有值都被认为是真值
,转换为布尔值时会得到true。
console.log(Boolean(0));
console.log(Boolean(""));
console.log(Boolean(null));
console.log(Boolean(undefined));
console.log(Boolean(NaN));
console.log(Boolean(123));
console.log(Boolean("hello"));
console.log(Boolean({}));
二、常见的强制类型转换场景
相等运算符 ==
与严格相等运算符 ===
在使用相等运算符==
时,JavaScript会进行强制类型转换以比较不同类型的值
。相反,严格相等运算符===
不会进行类型转换,只在两个值类型相同且值相等时返回true
。
console.log(123 == "123");
console.log(123 === "123");
算术运算符
当不同类型的值参与算术运算时,JavaScript会尝试将它们转换为数字
let result = "4" - 3;
console.log(result);
result = "5" + 5;
console.log(result);
逻辑运算符
逻辑运算符(&&、||、!)也会触发类型转换。它们通常会将操作数转换为布尔值,以决定运算结果
console.log(!!"hello");
console.log(!!0);
console.log(null || "default");
3、避免强制类型转换的陷阱
NaN陷阱
当尝试将非数值字符串转换为数字时,会得到NaN(Not-a-Number)
let result = Number("hello");
console.log(result);
null和undefined的特殊情况
null和undefined在进行类型转换时有一些特殊的行为,需要特别注意。
console.log(Number(null));
console.log(Number(undefined));
字符串连接与算术运算
由于+运算符既用于字符串连接又用于加法运算,容易引起混淆。
console.log("5" + 3);
console.log("5" - 3);