您的位置:首页 > Web前端 > JavaScript

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

2016-07-18 11:10 429 查看
[] == [];
[] === [];
{} == {};
{} === {};


结果:都为false

var n0 = 123;
var n1 = new Number(123);
var n2 = new Number(123);
var n3 = Number(123);
var n4 = Number(123);

n0 == n1; // true
n0 == n3; //true
n0 === n1; //false
n0 === n3; //true

n1 == n2; //false
n1 === n2; //false
n1 == n3; //true
n1 === n3; //false

n3 == n4; //true
n3 === 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?
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  javascript