浅谈jQuery绑定事件会叠加的解决方法和心得总结


Posted in Javascript onOctober 26, 2016

关于jQuery的学习中我忽略了一个取消绑定事件.unbind()的使用,也不知道绑定事件会累加的情况,结果因为这个原因,让我在项目上栽了坑。只能说自己还太年轻,需要学习掌握的知识还有很多。

我遇到的问题

我在项目中遇到的状况,一个评价页面,简单的来说就是左右两个表格,ajax分别动态加载学生姓名学号信息和不同科目对学生评价内容两部分,两边表格我都每行写了checkbox并对table tbody tr绑定click事件执行行选功能,起初我写的是静态页面html,行选功能完全没有问题,后来换成jsp页面,ajax动态加载数据进来后,问题就来了,由于ajax异步请求,两边表格发送请求加载数据有先后,之前静态页面测试好的行选功能就出了问题,每次刷新页面,只有后加载的部分才可以行选,之前加载的部分行选失效。自己控制台打印点击的状态console.log(chkBoxStatus);测试发现前加载的部分总是打印两次false true,而后加载的部分只打印一次false或是true。

我之前的行选代码段:

//行选功能 
  $("table tbody tr").click(function(event) {

  //遍历tr下的checkbox元素
  var $check = $(this).find("input[type=checkbox]");

  //判断非点击checkbox本身
  if($check.length > 0 && event.target != $check[0]) { 
    var chkBoxStatus = $check.is("input:checked");
    console.log(chkBoxStatus);
    $check.prop("checked", !chkBoxStatus); 
  }

  });

起初我认为我肯定是jQuery功能代码不对,于是自己检查了html里id,class,发现并没有出错,于是我便一直在想为何控制台会意外打印两次,后面室友提示我说,试试在执行功能之前清除事件绑定,于是我便照做了用jquery 的.unbind("click"),清除所有table上的click事件。结果!结果竟然成功了!!!两边的表格数据都可以正常进行行选功能,虽然是完成了预期功能,但是我当时不知道为什么要这样去做清除事件。后面我突然想到原来是执行了两次click事件的结果,每次先加载的数据,加载完毕后就被绑定click事件一次,后加载的数据加载完毕后,之前先加载的数据再次被绑定一次click事件,所以也就是为什么先加载的数据行选失效,打印两次false true , 而后加载的数据行选正常,打印一次。

下面是修改后的代码:

//行选功能 
  $("table tbody tr").unbind("click");//清除table的所有click事件  
  $("table tbody tr").click(function(event) {

  //遍历tr下的checkbox元素
  var $check = $(this).find("input[type=checkbox]");

  //判断非点击checkbox本身
  if($check.length > 0 && event.target != $check[0]) { 
    var chkBoxStatus = $check.is("input:checked");
    console.log(chkBoxStatus);
    $check.prop("checked", !chkBoxStatus); 
  }

  });

虽然问题很小,但是也是学习,总之自己还是需要不断努力,完善自己。博文只是对自己的总结

以上就是小编为大家带来的浅谈jQuery绑定事件会叠加的解决方法和心得总结全部内容了,希望大家多多支持三水点靠木~

Javascript 相关文章推荐
javascript 处理HTML元素必须避免使用的一种方法
Jul 30 Javascript
jquery多浏览器捕捉回车事件代码
Jun 22 Javascript
jquery json 实例代码
Dec 02 Javascript
在IE 浏览器中使用 jquery的fadeIn() 效果 英文字符字体加粗
Jun 02 Javascript
jQuery学习笔记之 Ajax操作篇(三) - 过程处理
Jun 23 Javascript
JS实现往下不断流动网页背景的方法
Feb 27 Javascript
JavaScript获取当前url根目录(路径)
Jun 17 Javascript
javascript数组常用方法汇总
Sep 10 Javascript
jQuery中常用动画效果函数(日常整理)
Sep 17 Javascript
解析JavaScript数组方法reduce
Dec 12 Javascript
JS常用倒计时代码实例总结
Feb 07 Javascript
详解auto-vue-file:一个自动创建vue组件的包
Apr 26 Javascript
关于Jquery中的事件绑定总结
Oct 26 #Javascript
IE8利用自带的setCapture和releaseCapture解决iframe的拖拽事件方法
Oct 25 #Javascript
理解JavaScript原型链
Oct 25 #Javascript
Ztree新增角色和编辑角色回显问题的解决
Oct 25 #Javascript
jQuery+json实现动态创建复杂表格table的方法
Oct 25 #Javascript
jQuery实现的小图列表,大图展示效果幻灯片示例
Oct 25 #Javascript
JavaScript prototype属性详解
Oct 25 #Javascript
You might like
PHP与MySQL开发中页面出现乱码的一种解决方法
2007/07/29 PHP
深入PHP autoload机制的详解
2013/06/09 PHP
ubuntu下配置nginx+php+mysql详解
2015/09/10 PHP
php中引用符号(&)的使用详细介绍
2016/12/06 PHP
laravel 实现向公共模板中传值 (view composer)
2019/10/22 PHP
php把文件设置为插件的技巧方法
2020/02/03 PHP
javascript div 遮罩层封锁整个页面
2009/07/10 Javascript
用js解决数字不能换行问题
2010/08/10 Javascript
JS解决url传值出现中文乱码的另类办法
2013/04/08 Javascript
jq选项卡鼠标延迟的插件实例
2013/05/13 Javascript
快速解决jQuery与其他库冲突的方法介绍
2014/01/02 Javascript
原生js获取宽高与jquery获取宽高的方法关系对比
2014/04/04 Javascript
原生js实现模拟滚动条
2015/06/15 Javascript
D3.js实现雷达图的方法详解
2016/09/22 Javascript
js 转义字符及URI编码详解
2017/02/28 Javascript
多个上传文件用js验证文件的格式和大小的方法(推荐)
2017/03/09 Javascript
javascript图片预览和上传(兼容IE)
2017/03/15 Javascript
php中and 和 &&出坑指南
2018/07/13 Javascript
微信小程序wx.request的简单封装
2019/11/13 Javascript
[48:56]2018DOTA2亚洲邀请赛 3.31 小组赛 A组 VG vs KG
2018/03/31 DOTA
[51:29]Alliance vs TNC 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/18 DOTA
python中pandas.DataFrame排除特定行方法示例
2017/03/12 Python
python 3.6 tkinter+urllib+json实现火车车次信息查询功能
2017/12/20 Python
Django 过滤器汇总及自定义过滤器使用详解
2019/07/19 Python
使用 Python 在京东上抢口罩的思路详解
2020/02/27 Python
在matplotlib中改变figure的布局和大小实例
2020/04/23 Python
Python定时任务APScheduler安装及使用解析
2020/08/07 Python
利用 CSS3 实现的无缝轮播功能代码
2017/09/25 HTML / CSS
印度低票价航空公司:GoAir
2017/10/11 全球购物
澳大利亚拥有最佳跳伞降落点和最好服务的跳伞项目运营商:Skydive Australia
2018/03/05 全球购物
戴森香港官方网站:Dyson香港
2021/02/11 全球购物
报到证丢失证明
2014/01/11 职场文书
感情真挚的毕业生求职信
2014/07/19 职场文书
出国签证在职证明
2014/09/20 职场文书
2014年学习部工作总结
2014/11/12 职场文书
运动会5000米加油稿
2015/07/21 职场文书