如果我将jQuery scroll
事件处理程序绑定到特定的命名空间......
$(window).on('scroll._my_namespace',function() { ... });
...有什么方法可以取消绑定所有scroll
事件处理程序,除了分配给该命名空间的事件处理程序?例如,如果我......
$(window).off('scroll._my_namespace');
...它会取消绑定特定的scroll
处理程序,如果我这样做......
$(window).off('scroll');
...它会取消绑定所有 scroll
处理程序。
到目前为止我尝试了什么:
$(window).off('scroll.'); // Doesn't seem to do anything
从来没有想到这会起作用,但我想在发布之前最好先尝试一下:
$(window).off('scroll:not("._my_namespace")'); // Also doesn't do anything
scroll
事件处理程序,除了分配给特定命名空间的事件处理程序。有没有办法做到这一点?答案 0 :(得分:2)
除了为所有必须删除的处理程序设置另一个公共命名空间之外,我不知道使用公共api的任何方式。
但是使用私人活动集合你可以尝试像
这样的东西var events = $._data(window, 'events');
for (var i = events.scroll.length - 1; i >= 0; i--) {
var handler = events.scroll[i];
if (handler && handler.namespace != 'ns') {
$(window).off('scroll', handler.handler)
}
}
$(window).on('scroll.ns', function(e) {
console.log('x', e.type, e.handleObj.namespace, e)
});
$(window).on('scroll.ns2', function(e) {
console.log('y', e.type, e.handleObj.namespace, e)
});
$(window).on('scroll.t', function(e) {
console.log('z', e.type, e.handleObj.namespace, e)
});
$('button').click(function() {
var events = $._data(window, 'events');
for (var i = events.scroll.length - 1; i >= 0; i--) {
var handler = events.scroll[i];
if (handler && handler.namespace != 'ns') {
$(window).off('scroll', handler.handler)
}
}
});

body {
height: 1000px;
}

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<button>Remove</button>
&#13;
答案 1 :(得分:0)
循环浏览您的名称空间,并为每个名称空间致电off
,但这是您不想要的名称。