当操作符两边的操作数类型不一致或者不是基本类型(也叫原始类型)时,需要进行类型转化。
隐式转换规则:
- 转成
string
类型: +(字符串连接符) - 转成
number
类型:++ / – (自增自减运算符)、+ - * / %(算术运算符)、 > <、 >= <=、 == != 、=== !=== (关系运算符) - 转成
boolean
类型:!(逻辑非运算符)
关系运算符的隐式转换:
知识点:
1、当关系运算符左右有一边是字符串时,会把其他数据类型转换成 Number 之后再比较关系
2、当关系运算符两边都是字符串时,会按照字符串对应的unicode编码转成number比较关系
3、多位字符串比较规则:先比较第一位,不等则出结果,相等则继续比较第二位,依次执行
实例:
1、'2' > 10 //false
2、'2' > '10' //true
3、'abc' > 'cba' //false
4、'abc' > 'aa' //true
解释:
1、Number('2') = 2
2、'2'.charCodeAt() = 50, '10'.charCodeAt() = 49
3、'a'.charCodeAt() = 97, 'b'.charCodeAt() = 98, 'c'.charCodeAt() = 99
4、见3
复杂类型的隐式转换:
非原始类型的数据,通过ToPrimitive() 将值转换成原始类型
ToPrimitive(input, PreferredType?)
该抽象操作接受两个参数:要转换的值input和转换目标类型PreferredType(可选);
该抽象操作的目的是把参数input转化为原始数据类型;
如果input可以同时转化为多个原始数据,那么会优先参考PreferredType的值;
针对没有PreferredType的情况:如果input为Date类型,则PreferredType被设置为String,其他情况,PreferredType被设置为Number处理;
如果input是原始数据类型,则该方法返回input自身,否则执行下述步骤转换
- 转换的数据类型是number(PreferredType == Number)
1、如果当前值已经是一个原始类型,则直接返回它 2、否则,如果当前值是一个对象,则先调用valueOf()方法,如果结果是原始类型则直接返回 3、否则,调用这个对象的toString()方法,如果结果是原始类型,则返回toString()结果 4、否则,抛出TypeError异常
- 转换的数据类型是String(PreferredType == String)
1、如果当前值已经是一个原始类型,则直接返回它 2、否则,如果当前值是一个对象,则先调用toString()方法,如果结果是原始类型则直接返回 3、否则,调用这个对象的valueOf()方法,如果结果是原始类型,则返回valueOf()结果 4、否则,抛出TypeError异常
实践:
知识点:
1、关系运算符:会把其他数据类型转换成 Number 之后再比较关系
2、以下值转化为Boolean结果为false,其余情况均为true
0,’’,NaN,false,null,undefined,document.all()
3、逻辑非 > 关系运算符(优先级)
实例:
1、[] == false //true
2、![] == false //true
3、[] == ![] //true
4、[] == [] //false
5、{} == {} //false
6、{} == !{} //false
解释:
1、[].valueOf().toString()返回空字符串,Number('')返回0
Number(false)返回0
2、逻辑非运算符会将值转成boolean类型,Boolean([])返回true,取反, Number(false)返回0
3、结合1,2,得出true
4、引用类型数据存储在堆中,栈中存储的是地址,所以为false
5、同4
6、{}调用.valueOf().toString()返回"[object Object]",Number("[object Object]")返回NaN
Boolean({})返回true,取反, Number(false)返回0