Ajax和jQuery处理程序
Ajax and jQuery handlers
我学习Ajax,我遇到了这个问题。
例如,我的标记是
<div id='ajax-container'>
..
<div class='some-class-with-handler'>
..
</div>
..
</div>
我有onClick-handler .some-class-with-handler-block
$(document).ready(function() {
..
$('.some-class-with-handler').click(function(){
..
});
..
}
然后Ajax重载# Ajax -container-block中的所有内容,但是。some-class-with-handler-block仍然包含在#ajax-container-block的新内容中。同时,onClick处理程序没有绑定到新的.some-class-with-handler-块。如何重新构建此绑定? 两个选择:
-
使用
jQuery.live
: http://api.jquery.com/live/Update:根据文档,
live
从1.7开始已弃用。您可以使用上述文档中提到的语法:$( selector ).live( events, data, handler ); // jQuery 1.3+ $( document ).delegate( selector, events, data, handler ); // jQuery 1.4.3+ $( document ).on( events, selector, data, handler ); // jQuery 1.7+
-
AJAX后重新绑定
click
处理程序var someClassClickHandler = function(){ .. }; $('.some-class-with-handler').click(someClassClickHandler); $.ajax({ success: function () { $('.some-class-with-handler').click(someClassClickHandler); } });
这是因为新的.some-class-with-handler
是一个新元素,你不能这样绑定新元素。这样修改你的处理器-
$(document).ready(function() {
..
$(document).on('click','.some-class-with-handler', function(){
..
});
..
}
相关文章:
- keyup事件处理程序更改焦点不适用于快速键入
- Webpack/Rect:遵循egghead.io教程,但出现错误:您可能需要一个合适的加载程序来处理此文件类型
- 提示使用服务器端事件处理程序激活JavaScript
- 将事件处理程序绑定到任何可能的事件
- 正在将事件处理程序添加到不存在的类
- 在AJAX回调和呈现PIXIJS之间处理程序流时遇到了问题
- Adobe Edge:动画完成时添加onComplete处理程序
- 是否可以从输入处理程序中确定输入的类型
- 在MVVM视图模型中处理应用程序范围的元素
- 在循环中附加事件处理程序时出现浏览器性能问题
- 在同一个javascript事件处理程序中调用不同的函数
- 有没有一种方法可以让内联事件处理程序在元素创建后立即执行
- 检查事件处理程序参数
- 实现延迟的jquery更改事件处理程序
- 如何使用Python/Selenium网络驱动程序处理Angularjs/Javascript下拉列表
- 在 AJAX 完成之前,不要让其他处理程序处理
- 如何使用硒铬驱动程序处理地理位置弹出窗口
- 如何使用硒网络驱动程序处理 onblur 事件
- 是否有一种方法为chrome打包应用程序处理Http BasicAuthentication
- Ajax加载程序处理问题