同一button可注册多个click事件

遇到一个bug,点击同一button会发送多个ajax请求,每次点击会累加发送之前的请求。 原因是同一button可多次注册多个事件。

$('#btn').on('click', function(){
  console.log('button click1');
});

$('#btn').on('click', function(){
  console.log('button click2');
});

上面的代码,btn同时注册了两个click事件,每次btn点击都会有两次输出。可通过off函数remove掉之前的click之后再重新注册新click事件,如下:

$('#btn').on('click', function(){
  console.log('button click1');
});

$('#btn').off('click').on('click', function(){
  console.log('button click2'); //only this output 
});
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • //------------------------- 第一章 认识JQuery ----------------...
    米塔塔阅读 4,059评论 0 9
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,314评论 19 139
  • 请参看我github中的wiki,不定期更新。https://github.com/ivonzhang/Front...
    zhangivon阅读 12,021评论 2 19
  • 1.几种基本数据类型?复杂数据类型?值类型和引用数据类型?堆栈数据结构? 基本数据类型:Undefined、Nul...
    极乐君阅读 10,938评论 0 106
  • 第一章 入门 基本功能:访问和操作 dom 元素,控制页面样式,对页面的事件处理,与ajax完美结合,有丰富的插件...
    X_Arts阅读 4,652评论 0 2