首页 > 开发 > AJAX > 正文

Ajax局部更新导致JS事件重复触发问题的解决方法

2024-09-01 08:32:53
字体:
来源:转载
供稿:网友

如果页面中包含一个ajax更新的列表,那么需要小心非动态更新部分的事件处理,下面以带有公共工具栏的列表界面为例

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

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

| Menu1 | Menu2

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

ID TITLE DESCRIPTION OPERATION

1 test1 hey test X - ...

2 test2 why not X - ...

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

  1. $.ajax(  
  2. ....  
  3. data: { ...  
  4. },  
  5. success: function(data) {  
  6. $('Menu1').click(  
  7. function(){  
  8. //do something  
  9. }  
  10. );  
  11. }  





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

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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表