1. JavaScript中的简单数据类型有哪些?
1、概述
JS 中有六种简单数据类型:undefined、null、boolean、string、number、symbol
ES10中的新特性 BigInt (任意精度整数),目前还处于stage-4阶段,不出意外即将成为js的第七种基本数据类型和第二个数字数据类型。
虽然变量的数据类型是不确定的,但是各种运算符对数据类型是有要求的,如果运算子的类型与预期不符合,就会触发类型转换机制
常见的类型转换有:
- 强制转换(显示转换)
- 自动转换(隐式转换)
2、显示转换
显示转换,常见的方法有:
- Number()
- parseInt()
- String()
- Boolean()
- Number()
将任意类型的值转化为数值
类型转换规则:
原始值 | 转换结果 |
---|---|
undefined | NaN |
Null | 0 |
true | 1 |
false | 0 |
String | 根据语法和转换规则来转换 |
Symbol | throw a typeError exception |
Object | 先调用toPrimitive,在调用toNumber |
Number(123) // 123
// 字符串:如果可以被解析为数值,则转换为相应的数值
Number('123') // 123
// 字符串:如果不可以被解析为数值,返回 NaN
Number('123abc') // NaN
// 空字符串转为0
Number('') // 0
// 布尔值:true 转成 1,false 转成 0
Number(true) // 1
Number(false) // 0
// undefined:转成 NaN
Number(undefined) // NaN
// null:转成0
Number(null) // 0
// 对象:通常转换成NaN(除了只包含单个数值的数组)
Number({x: 1}) // NaN
Number([1, 2, 3]) // NaN
Number([6]) // 6
Number转换的时候是很严格的,只要有一个字符无法转成数值,整个字符串就会被转为NaN
parseInt()
parseInt相比Number,就没那么严格了,parseInt函数逐个解析字符,遇到不能转换的字符就停下来
parseInt('123a3') //123
String()
可以将任意类型的值转化成字符串
给出转换规则图:
原始值 | 转换结果 |
---|---|
undefined | ’undefined’ |
Boolean | ‘true’ or ‘false’ |
Number | 对应的字符串类型 |
String | String |
Symbol | throw a typeError exception |
Object | 先调用toPrimitive,在调用toNumber |
// 数值:转为相应的字符串
String(1) // "1"
//字符串:转换后还是原来的值
String("x") // "x"
//布尔值:true转为字符串"true",false转为字符串"false"
String(true) // "true"
//undefined:转为字符串"undefined"
String(undefined) // "undefined"
//null:转为字符串"null"
String(null) // "null"
//对象
String({x: 1}) // "[object Object]"
String([1, 2, 3]) // "1,2,3"
Boolean()
可以将任意类型的值转为布尔值,转换规则如下:
Boolean(undefined) // false
Boolean(null) // false
Boolean(0) // false
Boolean(NaN) // false
Boolean('') // false
Boolean({}) // true
Boolean([]) // true
Boolean(new Boolean(false)) // true
3、隐式转换
可以归纳为两种情况发生隐式转换的场景:
比较运算(==、!=、>、<)、if、while
需要布尔值地方
算术运算(+、-、*、/、%)
自动转换为布尔值
在需要布尔值的地方,就会将非布尔值的参数自动转为布尔值,系统内部会调用Boolean函数
如:
- undefined
- null
- false
- +0
- -0
- NaN
- “”
除了上面几种会被转化成false,其他都换被转化成true
自动转换成字符串
遇到预期为字符串的地方,就会将非字符串的值自动转为字符串
具体规则是:先将复合类型的值转为原始类型的值,再将原始类型的值转为字符串
常发生在+运算中,一旦存在字符串,则会进行字符串拼接操作
'6' + 1 // '61'
'6' + true // "6true"
'6' + false // "6false"
'6' + null // "6null"
'6' + [] // "6"
'6' + undefined // "6undefined"
'6' + function (){} // "6function (){}"
'6' + {} // "6[object Object]"
自动转换成数值
除了+有可能把运算子转为字符串,其他运算符都会把运算子自动转成数值
true - 1 // 0
false - 1 // -1
false / '6' // 0
'6' - '2' // 6
'6' * '2' // 12
'1' - 1 // 0
'6' * [] // 0
'abc' - 1 // NaN
null + 1 // 1
undefined + 1 // NaN