Jquery on("click")方法绑定事件后执行多次的解决方法
一、发现问题
在开发过程中,无意发现页面弹窗按钮的点击事件使用on函数绑定click 时,产生多次请求,从而可能会造成不必要的资源消耗。
举例:
页面按钮:

代码片段:
let drBox = $('#choiceDetailPopup'),
// 提交
console.log("submitTask start");
drBox.on('click','#submitTask',function(){
console.log("submitTask click");
// 处理自己的业务逻辑 ……
})浏览器console:

二、解决问题
使用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()方法给元素绑定事件的时候要格外注意多次重复绑定的问题。
总结
相关文章
jquery attr 设定src中含有&(宏)符号问题的解决方法
今天在用 jquery 的attr 方法设定 iframe的src属性的时候遇到了一个奇怪的为题,现在把问题及解决方面写出来,让遇到同样问题的人不要在走弯路。2011-07-07
jQuery 移动端拖拽(模块化开发,触摸事件,webpack)
这篇文章主要介绍了jQuery 移动端拖拽(模块化开发,触摸事件,webpack)的相关资料,非常不错具有参考借鉴价值,需要的朋友可以参考下2016-10-10
jquery设置元素的readonly和disabled的写法
Jquery的api中提供了对元素应用disabled和readonly属性的方法,在这里记录下,感兴趣的朋友可以练练手了2013-09-09
jQuery/$ is not defined报错的几种解决方法
jQuery最常见的错误之一是$ is not defined错误,本文主要介绍了jQuery/$ is not defined报错的几种解决方法,具有一定的参考价值,感兴趣的可以了解一下2024-02-02


最新评论