[英]Can somebody explain this Javascript method?
原始来源: http : //twitter.com/tobeytailor/status/8998006366
(x=[].reverse)() === window // true
我注意到这种行为会影响所有本机类型。 到底发生了什么?
这与this
绑定在JavaScript中工作的奇怪方式有关。
[].reverse
是空列表上的reverse
方法。 如果您通过以下方式之一致电:
[].reverse();
[]['reverse']();
([].reverse)();
然后它执行this
绑定到列表实例[]
。 但如果你分开它:
x= [].reverse;
x();
它执行时没有this
绑定,所以this
函数指向全局( window
)对象,这是JavaScript中最糟糕,最误导性的设计错误之一。
(x=[].reverse)()
也正在做分离。 赋值运算符返回它传递的相同函数对象,因此看起来它什么都不做,但是它具有打破导致JavaScript绑定this
的有限特殊情况的副作用。
所以你说:
Array.prototype.reverse.call(window)
与许多其他Array.prototype
方法一样, reverse
由ECMAScript定义,可以处理任何类似本机序列的对象。 它使用数字字符串键(最多为object.length
)反转项目并返回该对象。 因此,它将返回为具有length
属性的任何类型传入的对象。
window
有一个length属性,对应于window.frames.length
,因此使用this
指向window
调用此方法将起作用并返回window
。 理论上它可能仍然失败,因为:
window
被允许是“主机对象”而不是“本机对象”; 在这种情况下,关于你可以传递给其他原型方法的保证并不一定适用; 和 但是,在当前的浏览器中,前一种情况确实有效,后者无故障地失败而没有错误,所以你仍然得到===window
行为而不是异常。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.