zoukankan      html  css  js  c++  java
  • ASP isPostBack

    源地址:http://blog.163.com/budong_weimin_zh/blog/static/129198524201061995455589/

    ASP.NET中IsPostBack详解  

    1、IsPostBack介绍
    Page.IsPostBack是一个标志:当前请求是否第一次打开。 调用方法为:Page.IsPostBack或者IsPostBack或者this.IsPostBack或者this.Page.IsPostBack,它们都等价。
      1)当通过IE的地址栏等方式打开一个URL时是第一次打开, 当通过页面的提交按钮或能
    引起提交的按钮以POST的方式提交的服务器时,页面就不再是第一次打开了。(每点击一次按钮,都是一次加载)
      2)IsPostBack只有在第一次打开的时候是false,其它时候都是true
      3).Net判断一个Page是否第一次打开的方法:Request.Form.Count>0
      4)每次页面Load的时候,根据需要把每次都要加载的代码放在IsPostBack中,只需要
    加载一次的代码放在if(!IsPostBack)中。
      5)每次用户回传服务器任何信息的时候,都会引发isPostBack属性用来判断此用户是

    否曾经做过登陆或者其他事件
      6 if(!IsPostBack)
      { 
      Response.Write("第一次提交!"); 
      } 
      if(IsPostBack) 
      { 
      Response.Write("按按钮!"); 
      } 
    2 IsPostBack结论
    本人对.Net的源代码中相关的处理进行的分析得到如下的结论:
    结论① 对于使用Server.Transfer进行迁移时迁移到的页面其IsPostBack=false。
    结论② Post方式如果Request中没有请求值,即Request.Form =null则IsPostBack=false
    ;Get方式如果Request中没有请求值,即Request.QueryString =null则IsPostBack=false。
    结论③ 如果QueryString或Form虽然有请求值,但是QueryString或Form中的Key没有
    “__VIEWSTATE”和“__EVENTTARGET”和“__VIEWSTATEFIELDCOUNT”,并且没有键为“null”,值以“__VIEWSTATE”开头并且也没有值为“__EVENTTARGET”的键值对,则IsPostBack=false。
    结论④ 使用Response.Redirect方式向自画面迁移时,此时IsPostBack=false。
    结论⑤ 发生跨页提交(CrossPagePostBack),当访问PreviousPage属性的时候,对于
    源PageIsPostBack=true。结论⑥ 发生跨页提交(CrossPagePostBack)时目标页面是IsPostBack=false
    结论⑦ 使用Server.Execute迁移到的页面其IsPostBack=false。
    结论⑧ 在Page运行期间其对应的DLL被更新了并且Page的树结构发生过变化,这种情况
    下请求时IsPostBack=false。
    可以这样来理解这些结论:一般情况判断Request中如果没有请求值则IsPostBack=false
    。如果有请求值但是不包括“__VIEWSTATE”等一些特殊的键或值,则IsPostBack=false(每次请求后.Net框架会将一些特殊的隐藏域

    “__VIEWSTATE”等返回给客户端)。还有一些特殊的情形是上面的规则不能正确判断的需要特殊处理的,这些情形包括Server.Transfer,Response.Redirect,CrossPagePostBack,Server.Execute,发
    生了页面元素变化及重新编译。

  • 相关阅读:
    Kubernetes 两步验证
    实战优化丨如何借助 CODING 实现云开发中的云函数的自动化部署
    弹性配置为构建提速
    一分钟开始持续集成之旅系列之:C 语言 + Makefile
    一分钟开始持续集成之旅系列之:Java + GWT
    静态网站架构的演进和最佳实践
    DevOps
    真香!CODING DevOps “极速构建计划”,再也不用担心构建慢了!
    CODING 敏捷实战系列课第二讲:Scrum 敏捷项目管理核心要素之 3355
    一分钟开始持续集成之旅系列之: Vue + 腾讯云 COS 上传部署
  • 原文地址:https://www.cnblogs.com/haizine/p/5828795.html
Copyright © 2011-2022 走看看