[英]Execute javascript after a partial postback of an updatepanel?
我有一个向其添加树文件脚本的页面。
<script type="text/javascript" src="js/jquery.min.js"></script>
<script type="text/javascript" src="js/init.js"></script>
<script type="text/javascript" src="js/easing.js"></script>
我有一个带有下拉列表的更新面板。 当运行 SelectedIndexChanged 事件(更新面板的部分回发)时,不要执行 javascript 。
使用pageLoad
函数:
function pageLoad(sender, args) {
InitialiseSettings();
}
function InitialiseSettings(){
// replace your DOM Loaded settings here.
// If you already have document.ready event,
// just take the function part and replace here.
// Not with document.ready
$(element).slideUp(1000, method, callback});
$(element).slideUp({
duration: 1000,
easing: method,
complete: callback});
}
或者,尝试使用.add_endRequest()
添加“结束请求”事件处理程序:
Sys.WebForms.PageRequestManager.getInstance().add_endRequest(InitialiseSettings)
编辑:
最好将代码从document.ready
移动到InitialiseSettings()
,然后将其注册为pageLoaded
事件处理程序。
代码示例
Sys.WebForms.PageRequestManager.getInstance().add_pageLoaded(InitialiseSettings)
要在全部和部分回发中运行您的 javascript,请将您的 javascript 代码放入 javascript pageLoad() 函数中。
function pageLoad()
{
//your javascript code
}
例子:
function pageLoad() {
$(':submit').click(function () {
CommodityArray();
});
$('#btn_image').click(function () {
CommodityArray();
});
$(".repHeader").disableSelection();
CommodityArray();
}
希望能帮助到你! :)
您必须在更新面板后使用以下代码。
<script type="text/javascript" language="javascript">
var pageRequestManager = Sys.WebForms.PageRequestManager.getInstance();
pageRequestManager.add_endRequest(NewCharacterCount);
</script>
其中NewCharacterCount
是您的 javascript 函数名称。
阅读这篇文章Sys.WebForms.PageRequestManager endRequest 事件希望它可以帮助你。
如果您正在使用 UpdatePanel 并且您想在更新面板中的内容刷新后调用 javascript 函数,您可以使用以下方法轻松完成。 在 Page body
标签中,调用函数RefreshContent()
<body onload="RefreshContent()">
<script type="text/javascript">
function RefreshContent()
{
Sys.WebForms.PageRequestManager.getInstance().add_endRequest(EndRequestHandler);
}
function EndRequestHandler()
{
alert("Add your logic here" );
}
</script>
您可以使用PageRequestManager 客户端事件。 sender 参数将包含您需要的信息。 例如,可以这样做:
// Register event handler
Sys.WebForms.PageRequestManager.getInstance().add_pageLoaded(pageLoaded);
/// Executed when all page content is refreshed, full page or async postback: https://msdn.microsoft.com/en-us/library/bb397523.aspx
function pageLoaded(sender, args) {
var isPostBack = sender.get_isInAsyncPostBack();
if(!isPostBack) return;
// PostBack logic here.
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.