event.currentTarget
和this
之间有区别吗?性能怎么样?
答案 0 :(得分:2)
currentTarget
event属性返回其事件侦听器触发事件的元素。这在捕获和冒泡期间特别有用。
您也可以使用this
关键字,但在使用Microsoft事件注册模型时,this
关键字不会引用HTML元素。
请参阅以下链接以获取更多信息:http://www.quirksmode.org/js/events_order.html
* Microsoft模式的问题 * l
但是当您使用Microsoft事件注册模型时,this关键字不会引用HTML元素。结合Microsoft模型中缺少类似currentTarget的属性,这意味着如果你这样做
element1.attachEvent('onclick',doSomething)
element2.attachEvent('onclick',doSomething)
您无法知道当前处理该事件的HTML元素。这是Microsoft事件注册模型中最严重的问题,对我来说,它的理由是永远不会使用它,即使在IE / Win仅应用程序中也是如此。
注意::它可能已经解决了
答案 1 :(得分:0)
jQuery文档明确指出,在大多数情况下event.currentTarget
等于this
(除非您使用jQuery.proxy
或类似方式手动更改范围):
此属性通常等于函数的属性。
如果您使用
jQuery.proxy
或其他形式的范围操作,this
将等于您提供的任何上下文,而不是event.currentTarget