zoukankan      html  css  js  c++  java
  • ASP.NET 2.0 读书笔记 圣殿 之 跨网页公布

    在ASP.NET 2.0使用以下四种方式:
    HyperLink
    Response.Redirect()
    Server.Transfer()
    Cross-Page Posting

    以下只说第四种,即“跨网页公布”
    区别于PostBack(只是自己ReCall自己),不再需要URL中的参数QueryString

    方法1:使用PreviousPage.FindControl访问来源网页A的空间属性属性。
    A页面有TextBoxA,在A页面的Button上设制PostBackUrl属性,为B页面。
    在B加载页面时:
        protected void Page_Load(object sender, EventArgs e)
        
    {
            TextBox txtB 
    = (TextBox)PreviousPage.FindControl("TextBoxA");
            Response.WriteLine(txtB.Text);
        }
    注意:这项技术只支持Button,LinkButton和ImageButton。

    方法2:使用@PreviousPageType访问来源网页A中的Public属性:
    还是A页面,A页面有TextBoxA,在A页面的Button上设制PostBackUrl属性,为B页面。后台代码公布属性:
    public partial class Default3 : System.Web.UI.Page
    {
        
    private string a;

        
    public string A
        
    {
            
    get return a; }
            
    set { a = value; }
        }

    }
    在B页面,设置如下,从而指定来源网页:
    <%@ PreviousPageType VirtualPath="~/A.aspx" %>
    在B加载页面时:
        protected void Page_Load(object sender, EventArgs e)
        
    {
            Response.Write(PreviousPage.A);
        }

    注意:一个页面只能由一个@PreviousPageType标签。即源与目标是一一对应的。


    方法3:使用@Reference,通过强类型来访问来源网页A中的Public成员。
    @Reference是通过将PreviousPage转换成与目标网页相同的类型,即强类型,这就不只可以访问属性了,还可以访问字段,方法等等,只要是public的。
    在目标B页面中添加
    <%@ Reference VirtualPath="~/A.aspx" %>
    那么在B中,就可以访问A这个页面类——基于文件系统的WebSite,其下的类是没有命名空间的,所以不能相互访问。
    假设源页面A是这样的:

    public partial class Default5 : System.Web.UI.Page
    {
        
    public string W;
        
        
    private string a = "a";

        
    public string A
        
    {
            
    get return a; }
            
    set { a = value; }
        }


        
    public string GetA()
        
    {
            
    return a;
        }

    }

    那么,在B加载页面时,

        protected void Page_Load(object sender, EventArgs e)
        
    {
            Default5 d5 
    = (Default5)PreviousPage;
            Response.Write(d5.A);

            Response.Write(d5.GetA());
        }

    说到这里,我自己试了一下,其实@PreviousPageType也可看作是强类型的,使用同方法三,只是相应在目标页面添加@PreviousPageType标签。。同时,我发现,只有添加了@PreviousPageType或@Reference后,目标页面类才能动态发现源目标类。

    再者,@PreviousPageType和@Reference的真正区别在于,一个页面只能由一个@PreviousPageType标签;但是一个页面却可以同时有多个@Reference,但这时候就需要额外的判断来源以决定相应的处理方法了,见下:
    假设目标页面B添加两个@Reference:

    <%@ Reference VirtualPath="~/Default5.aspx" %>
    <%@ Reference VirtualPath="~/Default3.aspx" %>

    B相应的加载过程:

       protected void Page_Load(object sender, EventArgs e)
        
    {
            
    try
            
    {
                
    if (PreviousPage != null)
                
    {
                    
    if (PreviousPage.IsCrossPagePostBack)
                    
    {
                        
    //将PreviousPage转换成与源网页相同的强类型
                        Default3 sourcePage = (Default3)PreviousPage;
                        Response.Write(sourcePage.A);
                    }

                }

            }

            
    catch
            
    {
            }


            
    try
            
    {
                
    if (PreviousPage != null)
                
    {
                    
    if (PreviousPage.IsCrossPagePostBack)
                    
    {
                        
    //将PreviousPage转换成与源网页相同的强类型
                        Default5 sourcePage = (Default5)PreviousPage;
                        Response.Write(sourcePage.GetA());
                    }

                }

            }

            
    catch
            
    {
            }

        }

    当然,也可以使用反射,从而写得不这么麻烦。
    还有PreviousPage的IsCrossPagePostBack属性,判断页面是否来自“跨网页公布”。(异曲同工于IsPostBack)

    “跨网页公布”原理:
    1.用户在源页面A按下Button后,根据其PostBackUrl属性,导向目标页面B
    2.B页面将A页面的ViewState另外存储一份后,销毁A页面的ViewState
    3.当在B页面中使用PreviousPage时,系统会自动初始化与A页面同一类型的Page,将其赋予PreviousPage,并在B页面Load_Complete阶段将原先保存的A页面ViewState还原给PreviousPage
    4.使用PreviousPage这个与源页面A相同的实体

    可以看到,“跨网页公布”的成本是很高的。

  • 相关阅读:
    iOS编译FFmpeg、kxmovie实现视频播放 (转载)
    CocoaPods 安装 使用
    如何做优化,UITabelView才能更加顺滑 (转载)
    iOS 保持界面流畅的技巧 (转载)
    ar命令详解
    ios 静态库冲突的解决办法
    【原】IOS合并lib(.a)库的终极可用方法(可用于解决duplicate symbol静态库冲突)
    react-native 学习之TextInput组件篇
    react-native 学习之Image篇
    js 对Array的补充
  • 原文地址:https://www.cnblogs.com/Jax/p/722927.html
Copyright © 2011-2022 走看看