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

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("暂无数据");
                }
        });

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值