动态生成dom元素时发生的重复绑定事件

来源:互联网 发布:公司注册淘宝店 编辑:程序博客网 时间:2024/04/29 10:08

dataTables服务器端先取出数据,然后初始化完成后给单元格内的a标签绑定click事件。
情景:第一次生成的表格点击后重新请求服务器,然后取出数据重新渲染表格

table = $("#searchTable").DataTable({.........}).on('click', 'tr', function(){            ......        });

点击第二次生成的表格会发现触发了两次点击事件,第三次生成的表格点击后触发了三次。
原因:上一次初始化表格完成后绑定的事件没有解绑。
解决办法:

$("#assPdArea").on('click','a.nextArea',function(){                  var str=this.name;                var data=str.split(',');                if(data[0] == 'Y'){                    getStaff(data[1]);                }else{                    alert("暂无数据");                }        });

将事件绑定在表格的外层容器上,设置目标元素符合指定的元素则触发点击事件,此时,该事件只绑定了一次。
这种办法也可以写在当页面暂时没有生成目标元素时的事件绑定,因为事件是绑定在外层容器上的。即事件代理。