类型转换
背景
JS
中有六种简单数据类型:undefined
、null
、boolean
、string
、number
、symbol
,以及引用类型:object
但是我们在声明的时候只有一种数据类型,只有到运行期间才会确定当前类型
1 | let x = y ? 1 : a |
常见的类型转换有:
- 强制转换(显示转换)
- 自动转换(隐式转换)
显示转换
显示转换,即我们很清楚可以看到这里发生了类型的转变,常见的方法有:
Number()
parseInt()
String()
Boolean()
Number()
原始值 | 转换结果 |
---|---|
Undefined |
NaN |
Null |
0 |
true |
1 |
false |
0 |
String |
根据语法和转换规则 |
Symbol |
TypeError |
Object |
先toPrimitive ,再toNumber |
1 | Number(324) // 324 |
parseInt()
parseInt
相比Number
,就没那么严格了,parseInt
函数逐个解析字符,遇到不能转换的字符就停下来
1 | parseInt('32a3') //32 |
String()
原始值 | 转换结果 |
---|---|
Undefined |
Undefined |
Boolean |
true or false |
Number |
对应的字符串类型 |
String |
String |
Symbol |
TypeError |
Object |
先toPrimitive ,再toNumber |
1 | // 数值:转为相应的字符串 |
Boolean()
数据类型 | 转换为true 的值 |
转换为false 的值 |
---|---|---|
Boolean |
true |
false |
String |
非空字符串 | “” 空字符串 |
Number |
非零数值 | 0 、NaN |
Object |
任意对象 | null |
Undefined |
N/A | undefined |
1 | Boolean(undefined) // false |
隐式转换
两种情况发生隐式转换的场景:
- 比较运算(
==
、!=
、>
、<
)、if
、while
需要布尔值地方 - 算术运算(
+
、-
、*
、/
、%
)
自动转换为布尔值
在需要布尔值的地方,就会将非布尔值的参数自动转为布尔值,系统内部会调用Boolean
函数
可以得出个小结:
- undefined
- null
- false
- +0
- -0
- NaN
- “”
除了上面几种会被转化成false
,其他都换被转化成true
自动转换成字符串
遇到预期为字符串的地方,就会将非字符串的值自动转为字符串
具体规则是:先将复合类型的值转为原始类型的值,再将原始类型的值转为字符串
常发生在+
运算中,一旦存在字符串,则会进行字符串拼接操作
1 | '5' + 1 // '51' |
自动转换成数值
除了+
有可能把运算子转为字符串,其他运算符都会把运算子自动转成数值
1 | '5' - '2' // 3 |
null
转为数值时,值为0
。undefined
转为数值时,值为NaN