javascript – 请解释.call(false)的怪异行为

前端之家收集整理的这篇文章主要介绍了javascript – 请解释.call(false)的怪异行为前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
> (function () { return this; }).call(false)
false

> !!(function () { return this; }).call(false)
true

在Firefox 4 beta和Chrome中都是最新的.

它就像……什么时候是布尔值,而不是布尔值?

解决方法

看来,当一个原始布尔值作为第一个参数传递给call或apply时,它会被自动装入一个Boolean对象. Firefox 4上的Firebug中很明显:
>>> (function () { return this; }).call(false)
Boolean {}

在Chrome的检查员中,它最初令人困惑,但有一点探索揭示了真相:

>>> (function () { return this; }).call(false)
false
>>> typeof (function () { return this; }).call(false)
"object"

所有JavaScript对象都是“truthy”,甚至是新的布尔值(false)和新的Number(0).因此,使用两个否定运算符(!!技巧)将它们转换为真正的布尔值.

猜你在找的JavaScript相关文章