参考答案:
JS
中有六种简单数据类型:undefined
、null
、boolean
、string
、number
、symbol
(BigInt
处理stage-4阶段,不考虑),以及引用类型:object
但是我们在声明的时候只有一种数据类型,只有到运行期间才会确定当前类型
1let x = y ? 1 : a;
上面代码中,x
的值在编译阶段是无法获取的,只有等到程序运行时才能知道
虽然变量的数据类型是不确定的,但是各种运算符对数据类型是有要求的,如果运算子的类型与预期不符合,就会触发类型转换机制
常见的类型转换有:
显示转换,即我们很清楚可以看到这里发生了类型的转变,常见的方法有:
将任意类型的值转化为数值
先给出类型转换规则:
实践一下:
1Number(324) // 324 2 3// 字符串:如果可以被解析为数值,则转换为相应的数值 4Number('324') // 324 5 6// 字符串:如果不可以被解析为数值,返回 NaN 7Number('324abc') // NaN 8 9// 空字符串转为0 10Number('') // 0 11 12// 布尔值:true 转成 1,false 转成 0 13Number(true) // 1 14Number(false) // 0 15 16// undefined:转成 NaN 17Number(undefined) // NaN 18 19// null:转成0 20Number(null) // 0 21 22// 对象:通常转换成NaN(除了只包含单个数值的数组) 23Number({a: 1}) // NaN 24Number([1, 2, 3]) // NaN 25Number([5]) // 5
从上面可以看到,Number
转换的时候是很严格的,只要有一个字符无法转成数值,整个字符串就会被转为NaN
parseInt
相比Number
,就没那么严格了,parseInt
函数逐个解析字符,遇到不能转换的字符就停下来
1parseInt('32a3') //32
可以将任意类型的值转化成字符串
给出转换规则图:
实践一下:
1// 数值:转为相应的字符串 2String(1) // "1" 3 4//字符串:转换后还是原来的值 5String("a") // "a" 6 7//布尔值:true转为字符串"true",false转为字符串"false" 8String(true) // "true" 9 10//undefined:转为字符串"undefined" 11String(undefined) // "undefined" 12 13//null:转为字符串"null" 14String(null) // "null" 15 16//对象 17String({a: 1}) // "[object Object]" 18String([1, 2, 3]) // "1,2,3"
可以将任意类型的值转为布尔值,转换规则如下:
实践一下:
1Boolean(undefined) // false 2Boolean(null) // false 3Boolean(0) // false 4Boolean(NaN) // false 5Boolean('') // false 6Boolean({}) // true 7Boolean([]) // true 8Boolean(new Boolean(false)) // true
在隐式转换中,我们可能最大的疑惑是 :何时发生隐式转换?
我们这里可以归纳为两种情况发生隐式转换的场景:
==
、!=
、>
、<
)、if
、while
需要布尔值地方+
、-
、*
、/
、%
)除了上面的场景,还要求运算符两边的操作数不是同一类型
在需要布尔值的地方,就会将非布尔值的参数自动转为布尔值,系统内部会调用Boolean
函数
可以得出个小结:
除了上面几种会被转化成false
,其他都换被转化成true
遇到预期为字符串的地方,就会将非字符串的值自动转为字符串
具体规则是:先将复合类型的值转为原始类型的值,再将原始类型的值转为字符串
常发生在+
运算中,一旦存在字符串,则会进行字符串拼接操作
1'5' + 1 // '51' 2'5' + true // "5true" 3'5' + false // "5false" 4'5' + {} // "5[object Object]" 5'5' + [] // "5" 6'5' + function (){} // "5function (){}" 7'5' + undefined // "5undefined" 8'5' + null // "5null"
除了+
有可能把运算子转为字符串,其他运算符都会把运算子自动转成数值
1'5' - '2' // 3 2'5' * '2' // 10 3true - 1 // 0 4false - 1 // -1 5'1' - 1 // 0 6'5' * [] // 0 7false / '5' // 0 8'abc' - 1 // NaN 9null + 1 // 1 10undefined + 1 // NaN
null
转为数值时,值为0
。undefined
转为数值时,值为NaN
最近更新时间:2024-08-10