Js隐式转换

JavaScript011

Js隐式转换,第1张

1 .if 判断,其余类型转为布尔类型

2 .比较操作符 ==

3 .+,-

4 . 点 号操作符

5 .在对数字,字符串进行点操作方法时,默认将数字,字符串转成对象

5 .关系符比较的时候

1 .

1 .null 转为“null”

2 .undefined 转为 “undefined”

3 .Boolean true转为“true”,false转为“false”

4 .number :11 转化为“11”,11e20 科学计数法转为“1.1e+21”

5 .数组,空数组转为字符串“”,如果数组中有null,或者undefined,同样当作空字符串处理,[1,2,3,4]="1,2,3,4"

6 .函数function a(){}转为字符串为 “function a(){}”

7 .一般对象:“[object,object]”

8 .NaN "NaN"

1 .只有null,undefined,0,false,NaN,空字符串,这6种情况转为布尔值的结果为false,其余都是true

2 .转换为布尔值得场景

1 .null 0

2 .undefined NaN

3 .Boolean true 1,false 0

4 .字符串:纯数字的字符串,转为对应的数字,空字符串转为0,其余都是NaN

5 .数组,数组首先会被转换为原始类型,然后根据上面的原始类型转换规则进行转换

6 .对象,和数组一样 {}=NaN

7 .NaN NaN

1 .Data对象会先调用toString

2 .当对象转为其他原始类型时,会先调用对象的valueOf方法,如果valueOf方法返回的是原始类型,直接返回这个原始类型

3 .返回的不是原始类型,或者valueOf方法不存在,继续调用toString()方法。如果toString()返回的是这个原始类型。直接返回这个原始类型,如果不是原始类型,直接报错

1 .将一个值转换为他为真正的布尔值

2 .!![] false ![]==true

1 .字符串和数字类型相比较的时候,字符串会被转换为数字类型

2 .布尔值和其他类型值比较

3 .null ,undefined 和其他类型的比较

4 .js规定null,undefined宽松都与自己相等,但是与其它值都不相等

1 .会把对象按照对象转换规则转换成原始类型,再次比较

1 .如果两个对象指向同一个对象,相等操作符返回true,否则返回 false

1 .字符串连接符的情况

这里有个js的概念: 隐式类型转换。 当你使用比较运算符时,js会进行隐式类型转换。

如果你又问,为什么会隐式类型转换呢,那我只能回答:这是js语言本身的特性,内部约定的。

隐式类型转换是遵循一定原则的

1. 两个数字比较时是不存在隐式类型转换的

2. 数字和非数字比较时,会将非数字的一方隐式转换成数字,然后进行比较。

3. 两个字符串进行比较时, 会将其第一个字母转成对应的ASCII,然后进行比较, 比如 'a' >'b', 会先将a 和 b 分别转换为其ASCII值: 97, 98, 因为 97 小于98,所以 'a' >'b' 为 false。

4. 两个boolean 类型比较时,true会被转换成1,false 会被转换为 0。

5. 两个对象进行比较时,会先调用其 valueOf方法,然后再进行比较。

基本就这些了,更多这方面的知识,需要你自己去加深了解了。