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("暂无数据");
}
});
将事件绑定在表格的外层容器上,设置目标元素符合指定的元素则触发点击事件,此时,该事件只绑定了一次。
这种办法也可以写在当页面暂时没有生成目标元素时的事件绑定,因为事件是绑定在外层容器上的。即事件代理。