Ajax局部更新导致JS事件重复触发问题的解决方法
Ajax局部更新导致JS事件重复触发问题的解决方法
发布时间:2016-12-30 来源:查字典编辑
摘要:如果在页面中包含一个ajax更新的列表,那么需要小心非动态更新部分的事件处理。以带有公共工具栏的列表界面为例:|Menu1|Menu2---...

如果在页面中包含一个ajax更新的列表,那么需要小心非动态更新部分的事件处理。

以带有公共工具栏的列表界面为例:

| Menu1 | Menu2

----------------------------------------------------------------------------

ID TITLE DESCRIPTION OPERATION

1 test1 hey test X - ...

2 test2 why not X - ...

----------------------------------------------------------------------------

$.ajax( .... data: { ... }, success: function(data) { $('Menu1').click( function(){ //do something } ); } )

由于Menu1界面部分是公共的,并不会随着列表数据的更新而被重新载入,那么上面的代码将产生重复的click事件触发(在多次更新列表后)。

所以我们要注意,在ajax列表更新的结果处理中,不能包含工具栏事件侦听的重新初始化。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类