这就比较长了,但是也很详细。这就不一条一条的解释了。 直接看第七条就好了: If Type(y) is Boolean, return the result of the comparison x == ToNumber(y). 那么结果就变成了: function() {} == 1 然后再看第9条: If Type(x) is Object and Type(y) is either String or Number, return the result of the comparison ToPrimitive(x) == y. 最后参考我一开始写的就好了。
懂了:
在if语句中:
在==操作符中:
赞! 感谢指导
值等于是比较值的。
所以浏览器会先将运算符两边的变量/表达式的值先算出来,并转换成同类型(基本类型)的形式进行比较。
(function(){})表达式的值通过valueOf()/toString()来计算,
你可以看一下这两个返回的值是什么,并且看一下返回值可否转换成为true。
抱歉打脸,今天有的别的事情。
-----------------update-----------------
更新:
@Starch
像这种比较运算符或者一些基本概念问题,我有一个推荐:
JavaScript 5
http://ecma-international.org...
JavaScript 6
http://ecma-international.org...
你可以到对应版本的JavaScript中寻找你需要的解释。
回到本题,先来看一下 == 运算符它的原理吧:
这个就是浏览器在遇到 == 时采取的操作步骤,我来翻译一下是什么意思:
那么在11.9.3,又是怎么规定abstract equality comparison 的呢?
这就比较长了,但是也很详细。这就不一条一条的解释了。
直接看第七条就好了:
If Type(y) is Boolean, return the result of the comparison x == ToNumber(y).
那么结果就变成了:
function() {} == 1
然后再看第9条:
If Type(x) is Object and Type(y) is either String or Number,
return the result of the comparison ToPrimitive(x) == y.
最后参考我一开始写的就好了。
答案就是false。
当 JavaScript 需要一个布尔值时(例如:if 语句),任何值都可以被使用。
最终这些值将被转换为 true 或 false
比如使用Boolean(function(){})返回true,在if语句中也会这样判断,因为它需要的是布尔值。
而==是判断类型返回布尔
并不是说function(){}为true, 你看看你的if判断里面只要不为null空 undefined 程序都能走通,所以这里并不能说明 function(){}==true;