jQuery是否覆盖事件侦听器
Does jQuery overwrite event listeners?
我有一堆div,每个div都包含一个附带点击事件的删除链接:
var observeRemoveRoom = function
$('.remove_room').click(function(){
$(this).parent().removeClass('active');
});
}
单击它将删除父级(div)的"活动"类。我在窗口加载时调用这个observeRemoveRoom
函数,它工作得很好。
问题是,我有另一个函数,它添加了更多相同的div。由于新div中包含的a.remove_room
链接不在window.load
上,我需要调用observeRemoveRoom
。
我是否以某种方式复制了事件处理程序?jQuery是否覆盖它们?如果是,我应该解除绑定处理程序吗?
每次调用observeRemoveRoom
时,jQuery都会为单击事件添加一个新的唯一事件处理程序函数。
因此,是的,您需要通过不带参数地调用.unbind()
来.unbind()
所有当前绑定的处理程序,或者是特定的并传入函数引用。
您可以尝试实时查询以保持它们的更新:http://docs.jquery.com/Plugins/livequery
是的,如果再次调用observeRemoveRoom
,您将复制事件处理程序,但这可能不会引起注意,因为您只是在调用removeClass
方法,如果找不到类,则该方法将不起任何作用,在触发第一个侦听器后会发生这种情况。
相反,您可以每次取消绑定并重新绑定点击事件,如:
var observeRemoveRoom = function(){
var remove_class = function(){
$(this).parent().removeClass('active');
};
$('.remove_room').off('click', remove_class).on('click', remove_class);
}
但也就是说,建议您在该函数之外执行此操作,而不是每次绑定和取消绑定事件,例如:
$(document).ready(function(){
var remove_class = function(){
$(this).parent().removeClass('active');
};
// If the element exists at dom ready, you can bind the event directly
$('.remove_room').on("click", remove_class);
// If the element is added in dynamically, you can [delegate][1] the event
$('body').on("click", '.remove_room', remove_class);
// Note: Although I've delegated the event to the body tag in this case
// I recommend that you use the closest available parent instead
});
http://api.jquery.com/on/#direct-和委托事件:[1]
相关文章:
- 如何在for循环中添加事件侦听器
- 未命中服务器发送的事件侦听器
- 如何覆盖原型中的事件侦听器
- 无法将事件侦听器附加到画布
- 如何在d3.js中自定义事件侦听器
- 在es6中,将带有回调的事件侦听器设置为可迭代的
- 事件侦听器未在chrome扩展中的options.js中启动
- IE8更改文本区域上的事件侦听器不工作
- 将事件侦听器添加到文档,而不是签入元素存在,然后添加事件侦听器
- javascript删除事件侦听器
- 我应该/如何清除mousemove JQuery事件侦听器
- 在JQuery中使用谷歌地图Api事件/侦听器
- 如何使用我的Jquery代码创建委托事件侦听器
- 'mousemove'画布中的事件侦听器-指针仅在最后一个矩形中更改
- 为什么此事件侦听器不工作
- 仅当类存在于Javascript中时才允许侦听器事件运行
- 不确定Google Maps的侦听器事件中值为何未定义
- 如何向控件添加侦听器事件
- 无法在地图单击侦听器事件上显示另一个地图
- Chrome运行时OnMessage侦听器事件未启动