(只记录易错转换)
一、 强制转换
1. Number()
(1) 原始类型值
// 字符串:如果不可以被解析为数值,返回 NaN |
与parseInt区别
parseInt('42 cats') // 42 |
(2) 对象
Number
方法的参数是对象时,将返回NaN
,除非是包含单个数值的数组。
Number({a: 1}) // NaN |
之所以会这样,是因为Number
背后的转换规则比较复杂。
第一步,调用对象自身的valueOf
方法。如果返回原始类型的值,则直接对该值使用Number
函数,不再进行后续步骤。
第二步,如果valueOf
方法返回的还是对象,则改为调用对象自身的toString
方法。如果toString
方法返回原始类型的值,则对该值使用Number
函数,不再进行后续步骤。
第三步,如果toString
方法返回的是对象,就报错。
var obj = {x: 1}; |
默认情况下,对象的valueOf
方法返回对象本身,所以一般总是会调用toString
方法,而toString
方法返回对象的类型字符串(比如[object Object]
)。所以,会有下面的结果。
Number({}) // NaN |
2. String()
(1) 原始类型值
String(123) // "123" |
(2) 对象
String({a: 1}) // "[object Object]" |
String
方法背后的转换规则,与Number
方法基本相同,只是互换了valueOf
方法和toString
方法的执行顺序。
- 先调用对象自身的
toString
方法。如果返回原始类型的值,则对该值使用String
函数,不再进行以下步骤。 - 如果
toString
方法返回的是对象,再调用原对象的valueOf
方法。如果valueOf
方法返回原始类型的值,则对该值使用String
函数,不再进行以下步骤。 - 如果
valueOf
方法返回的是对象,就报错。
3. Boolean()
它的转换规则相对简单:除了以下五个值的转换结果为false
,其他的值全部为true
。
Boolean(undefined) // false |
经测试,Boolean(false) == true
注意,所有对象(包括空对象)的转换结果都是true
,甚至连false
对应的布尔对象new Boolean(false)
也是true
二、 自动转换
1. 不同类型的数据互相运算
123 + 'abc' // "123abc" |
2. 对非布尔值类型的数据求布尔值
if ('abc') { |
3. 对非数值类型的值使用一元运算符(即+
和-
)
+ {foo: 'bar'} // NaN |
由于自动转换具有不确定性,而且不易除错,建议在预期为布尔值、数值、字符串的地方,全部使用Boolean
、Number
和String
函数进行显式转换。
参考文章: https://wangdoc.com/javascript/features/conversion.html