Jquery on(“click“) 方法绑定事件后执行多次解决办法

在这里插入图片描述

一、发现问题

在开发过程中,无意发现页面弹窗按钮的点击事件使用on函数绑定click 时,产生多次请求,从而可能会造成不必要的资源消耗。

举例:

页面按钮:

在这里插入图片描述

代码片段:


let drBox = $('#choiceDetailPopup'),

// 提交
console.log("submitTask start");
drBox.on('click','#submitTask',function(){
    console.log("submitTask click");
    // 处理自己的业务逻辑 ……
    
})

浏览器console:

image.png

二、解决问题

使用js动态加载内容,同时需要对加入的内容绑定点击事件的,on(‘click’,function(){}) 对同一个元素多次绑定同一个事件的时候,这个事件就会执行多次。

在每次绑定事件之前,对该事件解绑,可以使用的办法:


.off(“click”); //解除绑定点击事件
.unbind("click");//移除绑定点击事件
.unbind(); //移除所有绑定事件

我采用第一种办法,直接在 on 绑定 click 前,先释放,再绑定。

原代码片段修改如下:


let drBox = $('#choiceDetailPopup'),

// 提交
console.log("submitTask start");
drBox.off('click').on('click','#submitTask',function(){
    console.log("submitTask click");
    // 处理自己的业务逻辑 ……
})

修改后,浏览器console如下:

在这里插入图片描述

事件触发正常了。

实际的场景可能会复杂得多,因此在使用on()方法给元素绑定事件的时候要格外注意多次重复绑定的问题。




END

如有问题请在下方留言。

或关注我的公众号“孙三苗”(sunsanmiao),输入“联系方式”。获得进一步帮助。

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值