栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

jQuery $(document).ready和UpdatePanels?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

jQuery $(document).ready和UpdatePanels?

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)
因此您可以查看引发该事件的原因,并仅在需要时重新绑定。

这是来自Microsoft的文档的最新版本:msdn.microsoft.com/…/bb383810.aspx


根据您的需求,您可能有一个更好的选择是使用jQuery

.on()
。这些方法比每次更新都重新订阅DOM元素更为有效。但是,在使用此方法之前,请先阅读所有文档,因为它可能会满足您的需求,也可能无法满足您的需求。有很多jQuery插件无法重构为使用
.delegate()
.on()
,因此在这种情况下,最好重新订阅。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/442089.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号