阻止多次触发click操作

参考

jQuery 中 click事件会累计绑定

例如下面代码:

aNode.click(function(){
  bNode.click(function(){
    console.log('haha');
  });
});

如果把对bNode的点击事件绑定到aNode的点击事件里,那么每点击一次aNode就会绑定一次bNode,假设在点击bNode之前点击了3次aNode,那么点击bNode之后,控制台会出现三次haha。

因为jQuery中的click事件会累计绑定。

为了避免上述情况发生,有两种解决办法:
  1. 应该避免把click事件绑定到其他的例如click,hover等事件中。
aNode.click(function(){
});
bNode.click(function(){
  console.log('haha');
});
  1. 如果必须把click事件绑定在其他的例如click,hover等事件中的话(例如需要用到其他作用域中的变量,尤其是存在listitem这种情况下),需要用到unbind事件
$dom.unbind('click');
$dom.bind('click',funciton(){
     console.log('hahhaha');
});

在线调试

只触发一次click

参考
对于只需要触发一次,随后就要立即解除绑定的情况,JQuery提供了一种简写方法——one()方法。one()方法可以为元素绑定处理函数。当处理函数触发一次后,立即被删除。即在每个对象上,事件处理函数只会被执行一次。

one()方法的结构与bind()方法类似,使用方法也与bind()方法相同,其语法结构如下:one (type, [data], fn);

//使用one()方法为<button>元素绑定单击事件后,只在用户第1次单击按钮时,处理函数才执行,之后的单击就不会再起作用。
<script type="text/javascript">
        $(function () {
            $('#btn').one("click", function () {
                $('#test').append("<p>我的绑定函数1</p>");
            });
        })  
</script>    
<button id="btn">点击我</button>  
<div id="test"></div>  
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1.JQuery 基础 改变web开发人员创造搞交互性界面的方式。设计者无需花费时间纠缠JS复杂的高级特性。 1....
    LaBaby_阅读 4,910评论 0 1
  • jQuery 第三天知识点大纲 一、复习 第一天jQuery优点jQuery入口函数jQuery 选择器 第二天j...
    越IT阅读 3,218评论 2 2
  • 该来的总是会来。当别人已走远,你才恍然,自己奈何仍然原地止步不前。move on说起来那么简单的词语,为什么做起来...
    嬛姝阅读 1,852评论 0 0
  • 我一直觉得人性当中的阴暗面是与生俱来的,天知道,我妈并没有教我怎么嫉妒别人,但是我嫉妒时就是有不爽的感觉。‘画个圈...
    繁体兔阅读 2,854评论 0 4
  • 据苹果官方公告,OS X EL Capitan将会是最后一个支持Java 6的版本。但是作为开发者,Java ...
    Dxk611阅读 4,125评论 0 2