判断是否首次触发pageLoad 与 PageRequestManager.getInstance()对象的几个事件触发顺序...

   普通的Web页面初始加载时,我们一般会用if(!Page.IsPostBack)来判断一下该页面是初次加载还是通过回传加载。对于 ASP.NET AJAX  的客户端js脚本中的pageLoad事件也有它的是初始加载还是通过回发触发的pageLoad。
   刚跟皱键讨论具体怎么判断的问题,其想法与我的不谋而合,都是用一个全局变量来标识。不过后来经过一番研究,发现大可不必。按照如下代码来做
 
 1 None.gif   function  pageLoad(sender,e)
 2 ExpandedBlockStart.gifContractedBlock.gif         dot.gif {
 3InBlock.gif//此处e.get_isPartialLoad()即是判断是初始加载还是回发
 4InBlock.gif            if(e.get_isPartialLoad())
 5ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
 6InBlock.gif                Sys.WebForms.PageRequestManager.getInstance().add_initializeRequest(InitRequestHandler);
 7InBlock.gif                Sys.WebForms.PageRequestManager.getInstance().add_beginRequest(BeginRequestHandler);
 8InBlock.gif                Sys.WebForms.PageRequestManager.getInstance().add_endRequest(EndRequestHandler);
 9ExpandedSubBlockEnd.gif            }

10ExpandedBlockEnd.gif        }


只e.get_isPartialLoad()就ok了。

另外,Sys.Web.PageRequestManager.getInstance()的几个事件的顺序可以按照如下方式代码来测试一下,它们的顺序为
   initializeRequest→beginRequest→   向服务器端发送数据→接收数据→pageLoading→pageLoad→endRequest
 1 None.gif   function  pageLoad(sender,e)
 2 ExpandedBlockStart.gifContractedBlock.gif         dot.gif {
 3InBlock.gif            if(e.get_isPartialLoad()==false)
 4ExpandedSubBlockStart.gifContractedSubBlock.gif            dot.gif{
 5InBlock.gif                Sys.WebForms.PageRequestManager.getInstance().add_initializeRequest(InitRequestHandler);
 6InBlock.gif                Sys.WebForms.PageRequestManager.getInstance().add_pageLoading(PageLoadingHandler);
 7InBlock.gif                Sys.WebForms.PageRequestManager.getInstance().add_pageLoaded(PageLoadedHandler);
 8InBlock.gif                Sys.WebForms.PageRequestManager.getInstance().add_beginRequest(BeginRequestHandler);
 9InBlock.gif                Sys.WebForms.PageRequestManager.getInstance().add_endRequest(EndRequestHandler);
10ExpandedSubBlockEnd.gif            }

11ExpandedBlockEnd.gif        }

12 None.gif        
13 None.gif         function  PageLoadingHandler(sender,e)
14 ExpandedBlockStart.gifContractedBlock.gif         dot.gif {
15InBlock.gif            alert("PageLoading");
16ExpandedBlockEnd.gif        }

17 None.gif        
18 None.gif         function  PageLoadedHandler(sender,e)
19 ExpandedBlockStart.gifContractedBlock.gif         dot.gif {
20InBlock.gif            alert("PageLoaded");
21ExpandedBlockEnd.gif        }

22 None.gif         function  InitRequestHandler(sender,e)
23 ExpandedBlockStart.gifContractedBlock.gif         dot.gif {
24InBlock.gif            alert("InitRequestHandler");
25ExpandedBlockEnd.gif        }

26 None.gif        
27 None.gif         function  BeginRequestHandler(sender,e)
28 ExpandedBlockStart.gifContractedBlock.gif         dot.gif {
29InBlock.gif            alert("BeginRequestHandler");
30ExpandedBlockEnd.gif        }

31 None.gif        
32 None.gif         function  EndRequestHandler(sender,e)
33 ExpandedBlockStart.gifContractedBlock.gif         dot.gif {
34InBlock.gif            alert("EndRequestHandler");
35ExpandedBlockEnd.gif         }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值