为什么{} == false会在[] == false求值为true时评估为false?

时间:2015-01-16 17:16:50

标签: javascript boolean equality-operator

为什么{} == false评估为false[] == false在javascript中评估为true

1 个答案:

答案 0 :(得分:6)

这是根据Abstract Equality Comparison Algorithm

进行的类型转换
{} == false                // step 7 {} == ToNumber(false)
{} == 0                    // step 9 ToPrimitve({}) == 0
"[object Object]" == 0     // step 5 ToNumber("[object Object]") == 0
NaN == 0                   // step 1.c.i

[] == false                // step 7 [] == ToNumber(false)
[] == 0                    // step 9 ToPrimitve([]) == 0
"" == 0                    // step 5 ToNumber("") == 0
0 == 0                     // step 1.c.iii

参考文献:ToNumberToPrimitive

因此,更喜欢使用严格的比较。


在比较期间ToPrimitive如何将对象转换为基元的一些示例。默认情况下,将调用对象的valueOf方法,如果toString未返回原始值,则调用valueOf。对于Date个对象,默认情况下会调用toString

var obj = {};
obj.valueOf();        // Object { } // the object itself
obj.toString();       // "[object Object]"


obj.valueOf = function() { return 123; };
obj == 123; // true

obj.toString = function() { return 'foo bar'; };
obj == 123; // false
obj == 'foo bar'; // true

// Date object

var date = new Date();
date.valueOf();        // 1421430720379
date.toString();       // "Fri Jan 16 2015 09:52:00 GMT-0800 (PST)"

date == 1421430720379 // false
date == "Fri Jan 16 2015 09:52:00 GMT-0800 (PST)" // true

date.toString = function() { return 'foo'; };
date == 'foo'; // true