首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何使用jquery解除所有事件的绑定

如何使用jquery解除所有事件的绑定
EN

Stack Overflow用户
提问于 2010-08-26 03:13:08
回答 3查看 83.1K关注 0票数 77

我可以使用这段代码来删除click事件,

$('p').unbind('click')

但是,有什么方法可以删除所有的事件吗?

在jquery中有一个名为unbindAll的方法吗?

谢谢

EN

回答 3

Stack Overflow用户

发布于 2012-08-21 19:28:17

从jQuery 1.7开始,off()on()是绑定和解除绑定事件处理程序的首选方法。

因此,要从元素中删除所有处理程序,请使用以下命令:

$('p').off();

或者对于特定的处理程序:

$('p').off('click hover');

要添加或绑定事件处理程序,可以使用

$('p').on('click hover', function(e){
    console.log('click or hover!');
});
票数 84
EN

Stack Overflow用户

发布于 2017-02-01 01:43:44

@jammypeach是正确的,on & off是被接受的使用方法。Unbind有时会产生奇怪的行为(例如,实际上没有正确地解除绑定事件)。

要解绑正文中的所有元素,请找到所有元素,并为每个元素关闭click处理程序(旧的unbind是什么):

$("body").find("*").each(function() {
    $(this).off("click");
});

另请参阅如何保存已在this stack overflow question中关闭的事件。

票数 2
EN

Stack Overflow用户

发布于 2020-10-23 21:03:32

要从所有元素(包括文档)中删除所有事件绑定,请使用:

$(document).off().find("*").off();
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3569393

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档