位置: 编程技术 - 正文

浅谈jquery之on()绑定事件和off()解除绑定事件(jquery one())

编辑:rootadmin

推荐整理分享浅谈jquery之on()绑定事件和off()解除绑定事件(jquery one()),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jqueryon方法,jquery on函数,jquery on函数,jqueryon方法,jquery on(),jquery on(),jquery on(),jquery中on的用法,内容如对您有帮助,希望把文章链接给更多的朋友!

off()函数用于移除元素上绑定的一个或多个事件的事件处理函数。

off()函数主要用于解除由on()函数绑定的事件处理函数。

该函数属于jQuery对象(实例)。

语法

jQuery 1.7 新增该函数。其主要有以下两种形式的用法:

用法一:

jQueryObject.off( [ events [, selector ] [, handler ] ] )

用法二:

jQueryObject.off( eventsMap [, selector ] )

参数

参数 描述 events 可选/String类型一个或多个用空格分隔的事件类型和可选的命名空间,例如"click"、"focus click"、"keydown.myPlugin"。 eventsMap Object类型一个Object对象,其每个属性对应事件类型和可选的命名空间(参数events),属性值对应绑定的事件处理函数(参数handler)。 selector 可选/String类型一个jQuery选择器,用于指定哪些后代元素可以触发绑定的事件。如果该参数为null或被省略,则表示当前元素自身绑定事件(实际触发者也可能是后代元素,只要事件流能到达当前元素即可)。 handler 可选/Function类型指定的事件处理函数。

off()函数将会移除当前匹配元素上为后代元素selector绑定的events事件的事件处理函数handler。

如果省略参数selector,则移除为任何元素绑定的事件处理函数。

参数selector必须与通过on()函数添加绑定时传入的选择器一致。

如果省略参数handler,则移除指定元素指定事件类型上绑定的所有事件处理函数。

如果省略了所有参数,则表示移除当前元素上为任何元素绑定的任何事件类型的任何事件处理函数。

返回值off()函数的返回值为jQuery类型,返回当前jQuery对象本身。

实际上,off()函数的参数全是筛选条件,只有匹配所有参数条件的事件处理函数才会被移除。参数越多,限定条件就越多,被移除的范围就越小。

off()方法的代码示例:

容易忽略的点:off所解除元素的绑定事件,其中选择器必须和on绑定事件时所用的选择器一致。

html代码

页面加载时执行的jquery代码

浅谈jquery之on()绑定事件和off()解除绑定事件(jquery one())

on()函数用于为指定元素的一个或多个事件绑定事件处理函数。

此外,你还可以额外传递给事件处理函数一些所需的数据。

从jQuery 1.7开始,on()函数提供了绑定事件处理程序所需的所有功能,用于统一取代以前的bind()、 delegate()、 live()等事件函数。

即使是执行on()函数之后新添加的元素,只要它符合条件,绑定的事件处理函数也对其有效。

此外,该函数可以为同一元素、同一事件类型绑定多个事件处理函数。触发事件时,jQuery会按照绑定的先后顺序依次执行绑定的事件处理函数。

要删除通过on()绑定的事件,请使用off()函数。如果要附加一个事件,只执行一次,然后删除自己,请使用one()函数。

该函数属于jQuery对象(实例)。

语法

jQuery 1.7 新增该函数。其主要有以下两种形式的用法:

用法一:

jQueryObject.on( events [, selector ] [, data ], handler )

用法二:

jQueryObject.on( eventsMap [, selector ] [, data ] )

参数

参数 描述 events String类型一个或多个用空格分隔的事件类型和可选的命名空间,例如"click"、"focus click"、"keydown.myPlugin"。 eventsMap Object类型一个Object对象,其每个属性对应事件类型和可选的命名空间(参数events),属性值对应绑定的事件处理函数(参数handler)。 selector 可选/String类型一个jQuery选择器,用于指定哪些后代元素可以触发绑定的事件。如果该参数为null或被省略,则表示当前元素自身绑定事件(实际触发者也可能是后代元素,只要事件流能到达当前元素即可)。 data 可选/任意类型触发事件时,需要通过event.data传递给事件处理函数的任意数据。 handler Function类型指定的事件处理函数。

关于参数events中可选的命名空间,请参考最下面的示例代码。

关于参数selector,你可以简单地理解为:如果该参数等于null或被省略,则为当前匹配元素绑定事件;否则就是为当前匹配元素的后代元素中符合selector选择器的元素绑定事件。

参数handler中的this指向当前匹配元素的后代元素中触发该事件的DOM元素。如果参数selector等于null或被省略,则this指向当前匹配元素(也就是该元素)。

on()还会为handler传入一个参数:表示当前事件的Event对象。

参数handler的返回值与DOM原生事件的处理函数返回值作用一致。例如"submit"(表单提交)事件的事件处理函数返回false,可以阻止表单的提交。

如果事件处理函数handler仅仅只为返回false值,可以直接将handler设为false。

返回值

on()函数的返回值为jQuery类型,返回当前jQuery对象本身。

重要说明:

on()函数并不是为当前jQuery对象匹配的元素绑定事件处理函数,而是为它们的后代元素中符合选择器selector参数的元素绑定事件处理函数。on()函数并不是直接为这些后代元素挨个绑定事件,而是委托给当前jQuery对象的匹配元素来处理。由于DOM 2级的事件流机制,当后代元素selector触发事件时,该事件会在事件冒泡中传递给其所有的祖辈元素,当事件流传递到当前匹配元素时,jQuery会判断是哪个后代元素触发了事件,如果该元素符合选择器selector,jQuery就会捕获该事件,从而执行绑定的事件处理函数。

标签: jquery one()

本文链接地址:https://www.jiuchutong.com/biancheng/379366.html 转载请保留说明!

上一篇:jquery移除了live()、die(),新版事件绑定on()、off()的方法(jquery移出class)

下一篇:jQuery的ready方法实现原理分析(jquery(document).ready)

  • 小型微利企业所得税率
  • 一般纳税人金税盘抵税会计分录
  • 房地产开发企业土地增值税清算
  • 辞退职工赔偿金如何计算
  • 借款利息支出全部可以税前扣除吗
  • 备用金现金日记账表格
  • 计提坏账准备和冲减坏账准备
  • 无法收回的应收款计入什么科目
  • 购买债券取得的利息收入计入什么科目
  • 工会经费滞纳金税率
  • 实收资本没到账,一直挂其他应收款,有啥影响
  • 小微企业利润亏损原因
  • 一般纳税人能否享受残保金优惠
  • 其他法律依据
  • 收到发票,未付款,付款的时候需要把发票复印做附件吗
  • 采购材料差旅费怎么入账
  • 非公司车辆的使用费如何入账?
  • 个税返还手续费入什么科目
  • 合作方寄来的礼物能不能收?
  • 话费打印发票怎么缩小
  • 境内向境外提供服务免征增值税
  • 小企业出售无形资产发生的净损失应当计入什么科目
  • 1697510722
  • 购入成品油怎么做会计分录
  • 结转已经销售商品成本的分录
  • win11 桌面右键
  • PHP:stream_socket_pair()的用法_Stream函数
  • 周转材料要计入增值税吗
  • php imagecopymerge
  • avoid什么用法
  • 跨年度发票会计分录
  • 制造费用账户在期末被结平
  • php读取文件内容
  • 管家婆软件如何做账
  • 非成品油发票为什么不能抵扣
  • 红字发票信息表怎么打印出来
  • 开具培训类发票需要哪些条件?
  • 发票未认证跨月怎么办
  • 工资与劳务报酬是否合并缴纳个税
  • mysql清空缓存
  • 无形资产收益额的具体测算方法有
  • 领取营业执照后超过30天
  • 电子承兑对方拒绝签收多久能到账
  • 进口商品采购流程及时间
  • 购买的手机可以退货吗
  • 增值税专用发票有几联?
  • 研发人员工资加计扣除以实发
  • 旅行社开具的发票抵扣
  • 存货跌价准备确认损失分录
  • 一般纳税人租赁不动产增值税税率
  • 季节性停工计入成本吗
  • 如果找国外客户
  • 小企业购进商品怎么入账
  • 中标单位支付代理费
  • 制造费用和管理费用怎么结转
  • 支付水电费取得专用发票上注明税金0.68万元
  • 营改增后建筑企业如何正确开具发票
  • sql server的相关技术知识
  • windos桌面
  • win8激活点不进去
  • solaris 11.4
  • 电脑ios怎么安装
  • win7打开游戏显示已停止工作
  • win7系统鼠标右键菜单设置
  • 845主板支持1t硬盘吗
  • Win10怎么添加游戏
  • 一行指令
  • opengl中点画线算法
  • python利用matplotlib将扇形平分成50份
  • jquery validate文档
  • linux 加法命令
  • unity怎么创建字体
  • node.js详解
  • 查看本机开放端口号
  • 文件读写过程中,程序将直接与磁盘文件进行数据交换
  • javascript如何定义函数
  • 简述javascript中的函数
  • 工会经费申报表在哪里查询
  • 北京地税税务总局官网
  • 怎样在网上申报税务流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设