PageRequestManager类
-getInstance静态方法
获得全局唯一的PageRequestManager实例
-isInAsyncPostBack属性
是否正在处于一个异步更细过程中
-abortPostBack方法
取消当前的异步更新
多次调用不会产生异常
客户端的生命周期
Sys.Application与PageRequestManager共同形成
Sys._Application类
init 事件
load 事件
unload 事件
捷径方法
pageLoad方法
pageUnload方法
PageRequestManager的事件
异步刷新时触发
initializeRequest
beginRequest
pageLoading
pageLoaded
endRequest
进入页面
PRM-pageLoaded事件
App-init
App-load
pageLoad
离开页面
pageUnload 方法
App-unload事件
异步提交过程
发起一个异步提交
PRM-initializeRequest
PRM-beginRequest
服务器端处理
PRM-pageLoading(正常)
PRM-pageLoaded
App-load
pageLoad
PRM-endRequest(异常)
App-init事件
基于浏览器Window.onload 事件
所有脚本已经加载完毕
所有组件还没有开始创建
用于创建各种组件
这里给出一个App-init中实现更新优先级的程序
App-load与unload事件
load事件 参数类型(Sys.ApllicationLoadEventArgs)
components属性:获得这次加载阶段中所有建立对象
isPartialLoad属性:是否为异步调用导致页面加载
unload事件
用户通知
PRM-initializeRequest事件
reques属性 :用于获得WebRequest对象
postBackElement:触发异步刷新的Dom元素
常用操作:
读取此请求信息
取消此次异步刷新
Code
//解释下这里有两个按钮,提交这两个按钮都会产生异步的提交,通常是后面一个提交覆盖掉前面一个提交
//这里就在initializeRequest事件中实现一个优先按钮和一个普通按钮异步提交会不会被覆盖掉
<script type="text/javascript" language="javascript">
var lastPostBackButtonId = null;
//得到优先级高的按钮
var btnPrecedenceId = "<%= this.btnPrecedence.ClientID %>";
Sys.WebForms.PageRequestManager.getInstance().add_initializeRequest(
function(sender, e)
{
//获得PageRequestManager这个类的实例
var prm = Sys.WebForms.PageRequestManager.getInstance();
//调用get_isInAsyncPostBack判断这个实例是否处于回发当中
if (prm.get_isInAsyncPostBack())
{
//条件:上次更新处与回发当中
//判断上次按钮是否是优先按钮
if (lastPostBackButtonId == btnPrecedenceId)
{
//是的话,取消当前的异步更新
e.set_cancel(true);
//如果这次更新的提交的按钮是优先按钮
if (e.get_postBackElement().id == btnPrecedenceId)
{
showMessage("不可重复发起优先的刷新。");
}
else
{
showMessage("请等待优先的刷新结束。");
}
return;
}
else if (e.get_postBackElement().id == btnPrecedenceId)
{
showMessage("发起优先的刷新,普通的刷新将被取消。");
}
else
{
showMessage("重新发起普通的刷新,前一次提交将被取消。");
}
}
lastPostBackButtonId = e.get_postBackElement().id;
});
</script>
要点:为每个控件指定明确的ID
不要为页面中的UpdatePanel添加Trigger
使用ContentTemplateContainer属性向UpdatePanel内添加新控件
updatepanel必须要from控件中
InitializeRequest:它的作用主要是取消回发,和优先级,看看它的ventArgs有什么内容InitializeRequestEventArgs
get_postBackElement();可以得到引发回发的元素,例如,Button1引发了回发.我们用e.get_postBackElement()就可以得到这个Button的所有信息.get_request()获取表示当前回发的请求对象.set_cancel(Bool);取消回发.我们就是用它控制回发优先级.另外.一个同等级的回发单击 两次.如果第一次回发还没结束.就会被取消,接着实行第二次回发
PRM-beginRequest 事件
参数类型:BeginRequestEventArs
request属性:用于获得WebRequest对象
postBackElement:触发异步刷新的Dom元素
常用操作:
改取请求消息
改变请求方式
显示更新提示
这里要实现在外部按钮提交异步刷新显示UpdateProgress
Code
<script language="javascript" type="text/javascript">
Sys.WebForms.PageRequestManager.getInstance().add_beginRequest(
function(sender, e)
{
if (e.get_postBackElement().id != "<%= this.Button2.ClientID %>")
{
return;
}
var updateProgress = $get("<%= this.UpdateProgress1.ClientID %>");
var dynamicLayout = <%= this.UpdateProgress1.DynamicLayout.ToString().ToLower() %>;
if (dynamicLayout)
{
updateProgress.style.display = "block";
}
else
{
updateProgress.style.visibility = "visible";
}
});
</script>
PRM-pageLoading事件
dataItems属性:获得服务器注册的数据项
panelsDeleting属性:获得即将删除的UpdatePanel
panelsUpdating属性:获得即将更新的Updatepanel
即将要更新的Updatepanel样式改变
Code
<script language="javascript" type="text/javascript">
//改变样式的函数
function highlightPanels(panels, clear)
{
for (var i = 0; i < panels.length; i++)
{
var panel = panels[i];
panel.style.border = clear ? "solid 0px white" : "solid 2px red";
panel.style.backgroundColor = clear ? "white" : "#d6dde8";
}
}
Sys.WebForms.PageRequestManager.getInstance().add_pageLoading(
function(sender, e)
{
//这里注意获得即将要更新的updatepanel是一个数组
//也就是说会有好几个updatepanel会更新
var panelsUpdating = Array.clone(e.get_panelsUpdating());
highlightPanels(panelsUpdating);
//延迟的函数 进行清空
window.setTimeout(
function(){ highlightPanels(panelsUpdating, true); },
2000);
});
</script>
PRM-pageLoaded事件
参数类型:pageLoadedEventArgs
dataItems属性:获得服务器注册的数据项
panelsCreated属性:获得新建的UpdatePanel
panelsUpdated属性:获得应经更新的UpdatePanel
将更新的Updatepanel换一个位置
Code
<script language="javascript" type="text/javascript">
Sys.WebForms.PageRequestManager.getInstance().add_pageLoaded(
function(sender, e)
{
var upId = "<%= this.UpdatePanel1.ClientID %>";
//获得已经更新的Updatepanel是一个数组类型
var refreshedPanels = e.get_panelsUpdated();
for (var i = 0; i < refreshedPanels.length; i++)
{
if (refreshedPanels[i].id == upId)
{
refreshedPanels[i].id = upId + Math.floor(9999 * Math.random());
var div = document.createElement("div");
div.id = upId;
$get("commentContainer").appendChild(div);
return;
}
}
});
</script>
PRM-endRequest事件
参数类型:EndRequestEventArgs
dataItems属性:获得服务器注册的数据项
error属性:获得异步刷新时获得的错误
errorHandled属性:表明错误是否已经被处理了
response属性获得这次请求
这里以前就给出了例子了