首页 > web前端 > js教程 > jquery的on绑定点击事件执行两次如何解决

jquery的on绑定点击事件执行两次如何解决

小云云
发布: 2018-03-17 11:58:34
原创
2242 人浏览过

jquery中用.on()给页面中新加的元素添加点击事件时,点击事件源,绑定的事件执行两次,这里的alert会执行两次,相应地数组删除也执行两次,具体代码如下(其中.tabDel是页面加载之后新生成的元素,故不能用普通的$(‘.tabDel).click(function(){})的方法添加点击事件):

1

2

3

4

5

$('.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 事件之前,对该事件解绑,也就是

1

2

3

4

5

6

$('.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(),即:

1

2

3

4

5

6

7

$('.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()的语法是:

1

$(selector).unbind(event,function)

登录后复制

所以我就开始找其他解决问题的办法,知道后来发现在on绑定事件的时候没有阻止冒泡,在代码中加入 return false 阻止冒泡之后,事件正常运行了,代码如下:

1

2

3

4

5

6

$('.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 索引下标之li集合绑定点击事件实例分享

jQuery实现当按下回车键时绑定点击事件_jquery

JavaScript给按钮绑定点击事件(onclick)的方法_javascript技巧

以上是jquery的on绑定点击事件执行两次如何解决的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板