JavaScript 中一些值的比较,熟悉规范

来源:互联网 发布:护眼有什么软件 编辑:程序博客网 时间:2024/06/07 19:57
[] == [];[] === [];{} == {};{} === {};

结果:都为false

var n0 = 123;var n1 = new Number(123);var n2 = new Number(123);var n3 = Number(123);var n4 = Number(123);n0 == n1; // truen0 == n3; //truen0 === n1; //falsen0 === n3; //truen1 == n2; //falsen1 === n2; //falsen1 == n3; //truen1 === n3; //falsen3 == n4; //truen3 === n4; //true

例:
console.log( [] == !{} ); //why true?

!{}是个布尔值,为false,因此我们比较的是 [] == 0;

Number([])是0,因此我们比较的是 0 == 0;

其实我们需要解决三个问题:

(1)new Number(123) == Number(123); //true
Number函数要么返回一个数字,要么返回Not A Number(如果参数没有办法被转化为数字),在这三个例子中,我们不必担心NaN的问题,所以Number(123)等价于数字123。

于是(1)变成 new Number(123) == 123,进入规范 11.9.3-8

11.9.3-8提示我们去找ToPrimitive(Object(123))是什么,于是我们到了8.12.8–default value,一看,哎呦我去,正好有个valueof能用,于是(1)变成了 123 == 123;,结束。

(2)new Number(123) == new Number(123); //false
比较分支进入 11.9.3-1.f,就是看着两个Object的引用是不是相等的,这里明显是不等的。

(3)Number(123) == Number(123); //true
太简单了,omitted。

思考:

'foo' == new function(){ return String('foo'); };// false, why?'foo' == new function(){ return new String('foo'); };// true, why?
0 0