当前位置: 移动技术网 > IT编程>开发语言>JavaScript > js隐式转换的知识实例讲解

js隐式转换的知识实例讲解

2018年10月03日  | 移动技术网IT编程  | 我要评论

开胃菜

[] == ![]         //true ==> "" == false
123 ^ []          //123  ==> 123 ^ 0
~{}            //-1  ==> ~0
{} >= {1,2}        //true ==>因为大于等于的比较,不是相等的比较,所以[object object] >=[object object]
[null] == ""        //true ==> [""] == ""

值得注意的操作符:

一元操作符:通过number()进行转换;其中包括*号运算符,/号运算符,都是经number()转换

+undefined  //nan

逻辑运算符:!等价于boolean(),将操作数进行布尔值类型转换

位操作:~, |, &, ^;当一边操作数为nan时,可等价于操作数为0;

//由以下变化可以证得:
nan ^ nan ^ nan = 0

加号运算符,比较复杂

优先级最高的是字符串,任何操作数与字符串相加都将其string(x)成字符串,再进行字符串拼接

console.log("a" + 1);      //"a1"
console.log("a" + "1");     //"a1"
console.log("a" + false);    //"afalse"
console.log("a" + undefined);  //"aundefined"
console.log("a" + nan);     //"anan"
console.log("a" + null);    //"anull"
console.log("a" + {});     //"a[object object]"

其次number,而object在正常情况下输出的就是string类型

//console.log(1 + "1");   //"11"
console.log(1 + 1);     //2
console.log(1 + true);   //2 
console.log(1 + undefined); //nan
console.log(1 + nan);    //nan
console.log(1 + null);   //1
console.log(1 + {});    //"1[object,object]"

当一方为boolean,或者两方都是boolean时,都将其进行number处理,同理undefined与null也一样

console.log(true + true);   //2 
console.log(true + undefined); //nan
console.log(true + nan);    //nan
console.log(true + null);   //1
console.log((true + [nan]));  //"truenan"

减号,则将两边都进行number()处理

比较运算:==, >, <, >=, >=, != 遵循规则(摘自高程3):

1.null和undefined是相等的

2.要比较相等之前,不能将null和undfined转换成其他任何值

3.如有一个操作数为nan,相等操作符返回fasle,不相等操作符返回true, nan不等于nan

4.两个对象之间的比较,两者指向同一个对象(地址相同),相等操作符返回true,否则返回false

值得注意的是:对象间的>=与==(!=)比较方式是不同的,前者是tostring()返回值的比较,后者是引用地址的比较

当都是两边都是字符串时,按字符编码大小进行比较

当一方操作数为boolean,string,object,转成number类型的数值再进行比较;

console.log("nan" == nan);     //false
console.log(undefined == null);  //true
console.log({} >= {1:2});     //true
console.log({1:2} != {});     //true
console.log({} == {1:2});     //false
console.log([1] == [1]);      //false
console.log(null == 0);      //false

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网