我正在使用jQuery在UpdatePanel内的元素上连接一些鼠标悬停效果。事件绑定在$(document)中。准备好了。例如:
$(function() {
$('div._Foo').bind("mouseover", function(e) {
// Do something exciting
});
});
当然,这在页面第一次加载时工作得很好,但是当UpdatePanel进行部分页面更新时,它不会运行,鼠标悬停效果在UpdatePanel内部也不再工作。
在第一个页面加载时,以及每次UpdatePanel触发部分页面更新时,建议使用什么方法来连接jQuery中的内容?我应该使用ASP。NET ajax生命周期代替$(document).ready?
UpdatePanel完全替换更新面板上的内容。这意味着您订阅的那些事件不再订阅,因为更新面板中有新元素。
为了解决这个问题,我所做的是在每次更新后重新订阅我需要的事件。我使用$(document).ready()进行初始加载,然后使用Microsoft的PageRequestManager(如果您的页面上有更新面板,则可用)重新订阅每次更新。
$(document).ready(function() {
// bind your jQuery events here initially
});
var prm = Sys.WebForms.PageRequestManager.getInstance();
prm.add_endRequest(function() {
// re-bind your jQuery events here
});
PageRequestManager是一个javascript对象,如果页面上有一个更新面板,它就自动可用。只要UpdatePanel在页面上,除了上面的代码,您不需要做其他任何事情就可以使用它。
如果你需要更详细的控制,这个事件传递的参数类似于。net事件传递参数的方式(sender, eventArgs),所以你可以看到是什么引发了事件,只在需要时重新绑定。
下面是微软提供的文档的最新版本:msdn.microsoft.com/.../bb383810.aspx
根据需要,更好的选择是使用jQuery的.on()。这些方法比每次更新时重新订阅DOM元素更有效。但是,在使用这种方法之前请阅读所有文档,因为它可能满足也可能不满足您的需求。有很多jQuery插件如果要重构为使用.delegate()或.on()是不合理的,所以在这些情况下,你最好重新订阅。
我也遇到过类似的问题,发现最好的方法是依靠事件冒泡和事件委托来处理它。事件委托的好处是,一旦设置好,就不必在AJAX更新后重新绑定事件。
我在代码中所做的是在更新面板的父元素上设置一个委托。更新时不会替换此父元素,因此事件绑定不受影响。
有很多很好的文章和插件可以用jQuery处理事件委托,这个特性很可能会加入到1.3版本中。我用来参考的文章/插件是:
http://www.danwebb.net/2008/2/8/event-delegation-made-easy-in-jquery
一旦您理解了发生了什么,我认为您会发现这是一个更优雅的解决方案,比每次更新后都记得重新绑定事件更可靠。这还有一个额外的好处,即在卸载页面时为您提供一个可以解绑定的事件。