jQuery.undelegate()函数的使用详解
undelegate()函数用于移除元素上绑定的一个或多个事件的事件处理函数。
undelegate()函数主要用于解除由delegate()函数绑定的事件处理函数。
该函数属于jQuery对象(实例)。
语法
jQuery 1.4.2 新增该函数。其主要有以下三种形式的用法:
用法一:
jQueryObject.undelegate( [ selector , events [, handler ]] )
移除当前匹配元素为selector元素的events事件绑定的事件处理函数handler。
用法二:jQuery 1.4.3 新增支持该用法。
jQueryObject.undelegate( selector , eventsMap )
用法一的变体,用于同时移除多种事件类型的多个事件处理函数。eventsMap是一个对象,每个属性对应用法一中的参数events,值对应用法一中的参数handler。
用法三:jQuery 1.6 新增支持该用法。
jQueryObject.undelegate( namespace )
移除当前匹配元素上为所有元素的包含命名空间namespace的事件的所有事件处理函数。
参数
undelegate()函数将会移除当前匹配元素上为后代元素selector绑定的events事件的事件处理函数handler。
如果省略参数selector,则移除为任何元素绑定的事件处理函数。
参数selector必须与通过delegate()函数添加绑定时传入的选择器一致。
如果省略参数handler,则移除指定元素指定事件类型上绑定的所有事件处理函数。
如果省略了所有参数,则表示移除当前元素上为任何元素绑定的任何事件类型的任何事件处理函数。
返回值
undelegate()函数的返回值为jQuery类型,返回当前jQuery对象本身。
实际上,undelegate()函数的参数全是筛选条件,只有匹配所有参数条件的事件处理函数都将被移除。参数越多,限定条件就越多,被移除的范围就越小。
示例&说明
请参考下面这段初始HTML代码:
<input id="btn1" type="button" value="点击1" /> <input id="btn2" type="button" value="点击2" /> <a id="a1" href="#">CodePlayer</a>
首先,我们为上述button和元素绑定事件,然后使用undelegate()函数解除事件绑定,相应的代码如下:
function btnClick1(){ alert( this.value + "-1" ); } function btnClick2(){ alert( this.value + "-2" ); } var $body = $("body"); // 在body元素上为所有button元素的click事件绑定事件处理函数btnClick1 $body.delegate( ":button", "click", btnClick1 ); //在body元素上为所有button元素的click事件绑定事件处理函数btnClick2 $body.delegate( ":button", "click", btnClick2 ); //为所有a元素绑定click、mouseover、mouseleave事件 $body.delegate( "a", "click mouseover mouseleave", function(event){ if( event.type == "click" ){ alert("点击事件"); }else if( event.type == "mouseover" ){ $(this).css("color", "red"); }else{ $(this).css("color", "blue"); } }); //移除body元素为所有button元素的click事件绑定的事件处理函数btnClick2 //点击按钮,只执行btnClick1 $body.undelegate(":button", "click", btnClick2); //移除body元素为所有button元素的click事件绑定的所有事件处理函数(btnClick1和btnClick2) //点击按钮,不会执行任何事件处理函数 // $body.undelegate(":button", "click"); //注意: $body.undelegate("#btn1", "click"); 无法移除btn1的点击事件,undelegate()函数指定的选择器必须与delegate()函数传入的选择器一致。 // 移除body元素为所有元素(包括button和<a>元素)的任何事件绑定的所有处理函数 // 点击按钮、链接,或用鼠标在链接上移入、移出,都不会触发执行任何事件处理函数 //$("body").undelegate( );
此外undelegate()函数还可以只移除指定命名空间的所有元素的所有事件绑定。
var $body = $("body"); $body.delegate("#btn1", "click.foo.bar", function(event){ alert("click-1"); }); $body.delegate("#btn1", "click.test", function(event){ alert("click-2"); }); $body.delegate("#btn1", "click.test.foo", function(event){ alert("click-3"); }); // $body.undelegate(".test"); // 移除click-2、click-3 // $body.undelegate(".foo"); // 移除click-1、click-3 // $body.undelegate(".foo.bar"); // 移除click-1
以上是jQuery.undelegate()函数的使用详解的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

MetaMask(中文也叫小狐狸钱包)是一款免费的、广受好评的加密钱包软件。目前,BTCC已支持绑定MetaMask钱包,绑定后可使用MetaMask钱包进行快速登入,储值、买币等,且首次绑定还可获得20USDT体验金。在BTCCMetaMask钱包教学中,我们将详细介绍如何注册和使用MetaMask,以及如何在BTCC绑定并使用小狐狸钱包。MetaMask钱包是什么?MetaMask小狐狸钱包拥有超过3,000万用户,是当今最受欢迎的加密货币钱包之一。它可免费使用,可作为扩充功能安装在网络

Go语言提供了两种动态函数创建技术:closures和反射。closures允许访问闭包作用域内的变量,而反射可使用FuncOf函数创建新函数。这些技术在自定义HTTP路由器、实现高度可定制的系统和构建可插拔的组件方面非常有用。

在C++函数命名中,考虑参数顺序至关重要,可提高可读性、减少错误并促进重构。常见的参数顺序约定包括:动作-对象、对象-动作、语义意义和遵循标准库。最佳顺序取决于函数目的、参数类型、潜在混淆和语言惯例。

1、 SUM函数,用于对一列或一组单元格中的数字进行求和,例如:=SUM(A1:J10)。2、AVERAGE函数,用于计算一列或一组单元格中的数字的平均值,例如:=AVERAGE(A1:A10)。3、COUNT函数,用于计算一列或一组单元格中的数字或文本的数量,例如:=COUNT(A1:A10)4、IF函数,用于根据指定的条件进行逻辑判断,并返回相应的结果。

C++函数中默认参数的优点包括简化调用、增强可读性、避免错误。缺点是限制灵活性、命名限制。可变参数的优点包括无限灵活性、动态绑定。缺点包括复杂性更高、隐式类型转换、调试困难。

C++中的函数返回引用类型的好处包括:性能提升:引用传递避免了对象复制,从而节省了内存和时间。直接修改:调用方可以直接修改返回的引用对象,而无需重新赋值。代码简洁:引用传递简化了代码,无需额外的赋值操作。

自定义PHP函数与预定义函数的区别在于:作用域:自定义函数仅限于其定义范围,而预定义函数可在整个脚本中访问。定义方式:自定义函数使用function关键字定义,而预定义函数由PHP内核定义。参数传递:自定义函数接收参数,而预定义函数可能不需要参数。扩展性:自定义函数可以根据需要创建,而预定义函数是内置的且无法修改。
