关于attachEvent事件绑定的一点疑问.
问题说明
当在用attachEvent给元素添加事件的时候,默认的this 指向是window,为了在元素作用范围内,我们会进行如下处理.
function bind(obj,eventName,fn){
if(obj.addEventListener){
obj.addEventListener(eventName,fn,false);
}else{
obj.attachEvent('on'+eventName, function () {
fn.call(obj);//改变this指向 默认window
})
}
}
提问
这时候attachEvent 第二个参数传进去的是一个匿名函数所以我们无法通过detachEvent来移除添加的事件处理函数,那怎样才能既改变this指向又能方便的移除添加的事件处理函数呢?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
//添加
//移除