(转载)js(jquery)的on绑定点击事件执行两次的解决办法
js(jquery)的on绑定点击事件执行两次的解决办法—不是事件绑定而是事件冒泡
遇到的问题:jquery中用.on()给页面中新加的元素添加点击事件时,点击事件源,绑定的事件执行两次,这里的alert会执行两次,相应地数组删除也执行两次,具体代码如下(其中.tabDel是页面加载之后新生成的元素,故不能用普通的$(‘.tabDel).click(function(){})的方法添加点击事件):
 $('.right').on('click','.tabDel',function(){//删除所加 tab 节点的函数
               alert('tab的索引:'+$(this).parents('.contentLi2').index());
               var iNum1 = $(this).parents('.contentLi2').index();
               var iNum2 = $(this).parents('.anElement').index();
               $scope.module.tab[iNum1].fieldList.splice(iNum2,1);
               $(this).parents('.anElement').remove();
     });
上网找的解决方法大概有一下两种:
1、在用 on 绑定 click 事件之前,对该事件解绑,也就是
 $('.right').off('click','.tabDel').on('click','.tabDel',function(){//删除所加 tab 节点的函数
             // alert('tab的索引:'+$(this).parents('.contentLi2').index());
             var iNum1 = $(this).parents('.contentLi2').index();
             var iNum2 = $(this).parents('.anElement').index();
             $scope.module.tab[iNum1].fieldList.splice(iNum2,1);
             $(this).parents('.anElement').remove();
         });
2、在on绑定的click事件执行之后进行解绑,用unbind(),即:
 $('.right').on('click','.tabDel',function(){//删除所加 tab 节点的函数
             // alert('tab的索引:'+$(this).parents('.contentLi2').index());
             var iNum1 = $(this).parents('.contentLi2').index();
             var iNum2 = $(this).parents('.anElement').index();
             $scope.module.tab[iNum1].fieldList.splice(iNum2,1);
             $(this).parents('.anElement').remove();
         });
         $('.right .tabDel').unbind('clock');
然而,这也没有解决问题,我遇到的情况是这也写了之后,alert不执行了,原因是刚才说过:‘.tabDel’是页面上后来生成的元素,不能直接绑定事件,而unbind()的语法是:
所以我就开始找其他解决问题的办法,知道后来发现在on绑定事件的时候没有阻止冒泡,在代码中加入 return false 阻止冒泡之后,事件正常运行了,代码如下:
 $('.right').on('click','.tabDel',function(){//删除所加 tab 节点的函数
            // alert('tab的索引:'+$(this).parents('.contentLi2').index());
            var iNum1 = $(this).parents('.contentLi2').index();
            var iNum2 = $(this).parents('.anElement').index();
            $scope.module.tab[iNum1].fieldList.splice(iNum2,1);
            $(this).parents('.anElement').remove();
            return false;
        });
目前为止代码可以正常运行了,问题的元凶是冒泡,只是博主最开始找错了方向。
然而,阻止冒泡的方法并不止 return false 这一种,还有event.stopPropagation(),这两种方法是有区别的,简单来说:
event.stopPropagation()会阻止事件往上冒泡,但是并不阻止事件本身;
return false 则是既阻止了事件往上冒泡又阻止了事件本身。
欲详细了解这两种方法的区别,请查找相关资料。
参考文章:
Js 冒泡事件阻止
本文转载自:
js(jquery)的on绑定点击事件执行两次的解决办法—不是事件绑定而是事件冒泡
(转载)js(jquery)的on绑定点击事件执行两次的解决办法的更多相关文章
- 前端的事件冒泡(例如点击一次onclick事件执行两次)解决办法
		
问题概要: 当我运用antd 中 radio组件的时候发现radio组件是有bug的 就是你不能给他赋予id 和 value,同时也绑定不上onclick等事件.举个例子: 可以看到 你就算赋予了id ...
 - JS:   javascript 点击事件执行两次js问题 ,解决jquery绑定click事件出现点击一次执行两次问题
		
javascript 点击事件执行两次js问题 在JQuery中存在unbind()方法,先解绑再添加点击事件,解决方案为: $(".m-layout-setting").unbi ...
 - 通过jQuery给<li>绑定点击事件
		
背景:有个需求需要js中实现li标签的事件绑定,li通过在ajax请求中动态添加,按照常理,使用jQuery,可以使用以下方法绑定点击事件: $(function(){ commonAjaxCall ...
 - IOS的Safari浏览器中,点击事件失效的原理及解决办法
		
这里做了事件委托,简单区分一下[目标元素]和[代理元素],为后续论述理解做铺垫. [目标元素]:实际希望点击的元素,可以是任意标签. [代理元素]:代替[目标元素]触发点击事件的元素,有可能是目标元素 ...
 - Js,JQuery不同方式绑定的同一事件可以同时触发,互不干扰
		
比如,onclick绑定,然后jquery.on("click", function(){})绑定等
 - Jquery 事件执行两次
		
js(jquery)的on绑定点击事件执行两次的解决办法—不是事件绑定而是事件冒泡 阻止冒泡的方法并不止 return false 这一种,还有event.stopPropagation(),这两种方 ...
 - JQuery 动态加载 HTML 元素时绑定点击事件无效问题
		
问题描述 假设项目中有一个列表页面,如下: 当点击列表一行数据可以显示详情页面,而详情页面的数据是根据当前行的数据作为参数,通过 ajax 请求到后台返回的数据,再根据返回的结果动态生成 html 页 ...
 - jQuery实现当按下回车键时绑定点击事件
		
jQuery实现当按下回车键时绑定点击事件 <script> $(function(){ $(document).keydown(function(event){ if(event.key ...
 - 由于js词法性质和全局变量被更改,循环绑定的click事件执行时变量和定义时 不一致的bug,各种解决方案。
		
由于js词法性质和全局变量被更改,循环绑定的click事件执行时变量和定义时 不一致的bug,各种解决方案. 动态在页面上添加了5个按钮,实现的功能应该是点击对应按钮在控制台输出相应的索引.但因为应该 ...
 
随机推荐
- Matplotlib绘图属性(1)
			
[matplotlib颜色.形状.线型等详细配置方法] #1.颜色(三种方法)-color 八种内置颜色及其缩写: b:blue <蓝色> c:cyan <青色> g:gree ...
 - windows下在指定目录下打开命令行
			
直接用cd的话比较麻烦,可以先进入制定目录后,按住shift键,鼠标右键可以选择“在此处打开命令窗口”
 - 82. Spring Boot – 启动彩蛋【从零开始学Spring Boot】
			
我们在[28. SpringBoot启动时的Banner设置 ] 这一小节介绍过设置Spring Boot的Banner,但是实际当中,我们希望做的更漂亮,所以也就有了这小节Spring Boot-启 ...
 - rsync同步命令
			
rsync同步时,--delete删除目标目录比源目录多余文件的方法1 .实例说明 服务器A上同步/tmp/work目录到远程服务器B的/tmp/work目录下, 同时删除B服务器/tmp/work ...
 - iOS NSLog各种打印
			
%@ 对象 %d,%i 整型 (%i的老写法) %hd 短整型 %ld , %lld 长整型 %u 无符整型 %f 浮点型和double型 %0.2f 精度浮点数,只保留两位小数 %x: 为32 ...
 - Jackson转换JSON例子
			
Jackson可以轻松的将Java对象转换成json对象和xml文档,同样也可以将json.xml转换成Java对象. 前面有介绍过json-lib这个框架,在线博文:http://www.cnblo ...
 - OI 数论整理
			
1.素数: 质数(prime number)又称素数,有无限个.一个大于1的自然数,除了1和它本身外,不能被其他自然数整除,换句话说就是该数除了1和它本身以外不再有其他的因数;否则称为合数. 2016 ...
 - asp.net在IE10下事件丢失排错经过
			
下午看一篇文章,感觉对以后自己开发有点用途,摘抄下来. 原文出处:http://www.cnblogs.com/weapon/archive/2013/06/23/3150584.html 最近项目中 ...
 - 标准C程序设计七---00
			
以下内容为阅读: <21天学通C语言>(第7版) 作者:Bradley Jones Peter Aitken Dean Miller(美), 姜佑译 人民邮电出版社 2014.11 ...
 - Python入门--5--列表
			
python没有数组 蛋是有列表 列表里面可以有:整数,浮点数,字符串,对象 没有数组,没有数组,没有数组,不重要的也说三遍!! 一.创建列表 x = ['abc','sas','www'] ...