• C#中页面传值的方法。转载


    .net(c#)跨页面传值哪几种方式?

    1.querystring的方式:将需要的值直接写到链接的后面,这些内容将直接显示到地址栏中,在传递安全性要求不高的一个或多个值或者是结构简单的值就可以使用这样的方法。
    
    如: Response.Redirect( "target.aspx?param1=hello¶m2=hi ")
    
    在接收页面可以通过request的方式得到所传递的值:   string   str   =   Request.QueryString["param1"];
    
    2.cookie方式,使用cookie对象方式,cookie是放在客户端的
    
    设置Cookie:   HttpCookie cookie_name = new HttpCookie("name");
    
                          cookie_name.Value = Label1.Text;
    
                          Reponse.AppendCookie(cookie_name);
    
    获取Cookie:
    
                          string name= Request.Cookie["name"].Value.ToString();
    
    3.session变量,session是放置于服务器端的
    
    设置Session:      Session["name"] ="hello";
    
    获取Session:        string name = Session["name"].ToString();
    
    4.使用Application 对象变量
    
    Application对象的作用范围是整个全局,也就是说对所有用户都有效。此种方法不常使用,因为Application在一个应用程序域范围共享,所有用户可以改变及设置其值,故只应用计数器等需要全局变量的地方。
    
    设置Application :    Application["name"] = ="hello";
    
    获取Application :     string   name = Application["name"].ToString();
    
    5. PostBackUrl()方法
    
    default.aspx页面:
    
    Code
    
    1 <asp:Button ID="Button1" Runat="server" Text="PostToAnotherPage" PostBackUrl="~/Default2.aspx" />
    
    2
    
    default2.aspx页面:
    
    Code
    
    1 if (PreviousPage != null)
    
    2        {
    
    3            TextBox textBox1 = (TextBox)PreviousPage.FindControl("TextBox1");
    
    4           Response.write(textBox1.Text );
    
    5        }、
    
    6.用Server.Transfer方法
    
        这个才可以说是面象对象开发所使用的方法,其使用Server.Transfer方法把流程从当前页面引导到另一个页面中,新的页面使用前一个页面的应答流,所以这个方法是完全面象对象的,简洁有效。下面这个代码是展示在需要很多个参数的时候,使用的方法,如果参数比较少就没必要使用这个方法了.
    
    如果让所有的查询页面都继承一个接口,在该接口中定义一个方法,该方法的唯一作用就是让结果页面获得构建结果时所需的参数,就可实现多页面共享一个结果页面操作!
    
    1、先定义一个类,用该类放置所有查询参数:
    
    Code
    
    /**//// <summary>
    
    /// QueryParams 的摘要说明
    
    /// </summary>
    
    public class QueryParams
    
    {
    
    private   string   firstName;
    
            private   string   lastname;
    
            private   int    age;
    
         
    
             public string Firstname
    
            {
    
                get { return this.firstname; }
    
                set { this.firstname = value; }
    
            }
    
            public string LastName
    
            {
    
                get { return this.lastname; }
    
                set { this.lastname = value; }
    
            }
    
            public string Age
    
            {
    
                get { return this.age; }
    
                set { this.age = value; }
    
            }
    
    }
    
    2、接口定义:
    
    Code
    
    /**////   <summary >
    
        ///   定义查询接口。
    
        ///   </summary >
    
        public interface IQueryParams
    
        {
    
            /**////   <summary >
    
            ///   参数
    
            ///   </summary >
    
            QueryParams Parameters { get;}
    
        }
    
         3、查询页面继承IQueryParams接口(QueryPage.aspx):
    
    QueryPage.aspx
    
    Code
    
    <form id="form1" runat="server">
    
        <div>
    
            <asp:TextBox ID="txtFirstName" runat="server"></asp:TextBox>
    
            <asp:TextBox ID="txtLastName" runat="server"></asp:TextBox>
    
             <asp:TextBox ID="txtAge" runat="server"></asp:TextBox>
    
            <asp:Button ID="btnEnter" runat="server" Text="Button" OnClick="btnEnter_Click" /></div>
    
        </form>
    
    QueryPage.aspx.cs
    
    Code
    
    public partial class QueryPage : System.Web.UI.Page, IQueryParams
    
    {
    
        private QueryParams queryParams;
    
      
    
            public   QueryParams   Parameters
    
            {
    
                get
    
                {
    
                     return   queryParams;
    
                }
    
            }
    
          
    
            public   void   btnEnter_Click(object   sender,   System.EventArgs   e)
    
            {
    
                //赋值
    
                queryParams   =   new   QueryParams();
    
                queryParams.FirstnName = this.txtFirstName.Text;
    
                queryParams.Lastname = this.txtLastName.Text;
    
                queryParams.Age = this.txtAge.Text;
    
                Server.Transfer( "ResultPage.aspx ");
    
            }
    
        protected void Page_Load(object sender, EventArgs e)
    
        { }
    
    }
    
    4、接收页面(ResultPage.aspx):
    
    ResultPage.aspx.cs
    
    public partial class ResultPage : System.Web.UI.Page
    
    {
    
        protected void Page_Load(object sender, EventArgs e)
    
        {
    
            QueryParams queryParams = new QueryParams();
    
            IQueryParams queryInterface;
    
            //实现该接口的页面
    
            if (Context.Handler is IQueryParams)
    
            {
    
                queryInterface = (IQueryParams)Context.Handler;
    
                queryParams = queryInterface.Parameters;
    
            }
    
            Response.Write("FirstName: ");
    
            Response.Write(queryParams.FirstName);
    
            Response.Write(" <br/ >Lastname: ");
    
            Response.Write(queryParams.LastName);
    
            Response.Write(" <br/ >Age: ");
    
            Response.Write(queryParams.Age);
    
        }
    
    }
    ——————————————————————————————————————————————————————————————

    一、目前在ASP.NET中页面传值共有这么几种方式:

    1、表单提交,
       <form action= "target.aspx" method = "post" name = "form1">
     <input name = "param1" value = "1111"/>
     <input name = "param2" value = "2222"/>
       </form>
       ....
       form1.submit();
       ....
       此种方在ASP。NET中无效,因为ASP。NET的表单总是提交到自身页面,如果要提交到别一页面,需要特殊处理。
    2、<A href="target.aspx?param1=1111&param2=2222">链接地址传送</A>
    接收页面: string str = Request["param1"]
    3、Session共享
    发送页面:Session("param1") = "1111"; 
    按收页面  string str = Session("param1").ToString(); 
    4、Application共享
    发送页面: Application("param1") = "1111";  
    按收页面: string str = Application("param1").ToString(); 
    此种方法不常使用,因为Application在一个应用程序域范围共享,所有用户可以改变及设置其值,故只应用计数器等需要全局变量的地方。
    5、Cookie
    6、Response.Redirect()方式
       Response.Redirect("target.aspx?param1=1111&param2=2222")
       接收页面: string str = Request["param1"]
    7、Server.Transfer()方式。
       Server.Transfer("target.aspx?param1=1111&param2=2222")
       接收页面: string str = Request["param1"]

    二、如果在两个页面间需要大量的参数要传传递,如数据查询等页面时,用1 - 6的方法传值及其不便,而第 7 种方法确有一独特的优势!但使用该方法时需要一定的设置,现简单介绍一下该方法的使用方式:

      以查询数据页面为例:

       在查询页面中设置如下公有属性(QueryPage.aspx):

        public class QueryPage : System.Web.UI.Page
    {
    protected System.Web.UI.WebControls.TextBox txtStaDate;
    protected System.Web.UI.WebControls.TextBox txtEndDate;
       ...
    /// <summary>
    /// 开始时间
    /// </summary>
    public string StaDate
    {
    get{ return this.txtStaDate.Text;}
    set{this.txtStaDate.Text = value;}
    }
    /// <summary>
    /// 结束时间
    /// </summary>
    public string EndDate
    {
    get{ return this.txtEndDate.Text;}
    set{this.txtEndDate.Text = value;}
    }
    ....
    private void btnEnter_Click(object sender, System.EventArgs e)
    {
    Server.Transfer("ResultPage.aspx");
    }
    }

       在显示查询结果页面(ResultPage.aspx):

        public class ResultPage : System.Web.UI.Page
    {
       private void Page_Load(object sender, System.EventArgs e)
       {
    //转换一下即可获得前一页面中输入的数据
    QueryPage queryPage = ( QueryPage )Context.Handler;
    Response.Write( "StaDate:" );
    Response.Write( queryPage.StaDate );
    Response.Write( "<br/>EndDate:" );
    Response.Write( queryPage.EndDate );
      }
    }

    三、如果有许多查询页面共用一个结果页面的设置方法:

        在这种方式中关键在于“ QueryPage queryPage = ( QueryPage )Context.Handler; ”的转换,只有转换不依赖于特定的页面时即可实现。

    如果让所有的查询页面都继承一个接口,在该接口中定义一个方法,该方法的唯一作用就是让结果页面获得构建结果时所需的参数,就可实现多页面共享一个结果页面操作!

    1、先定义一个类,用该类放置所有查询参数:

    /// <summary>
    /// 结果页面中要用到的值
    /// </summary>
    public class QueryParams
    {
    private string staDate;
    private string endDate;
    /// <summary>
    /// 开始时间
    /// </summary>
    public string StaDate
    {
    get{ return this.staDate;}
    set{this.staDate = value;}
    }
    /// <summary>
    /// 结束时间
    /// </summary>
    public string EndDate
    {
    get{ return this.endDate;}
    set{this.endDate = value;}
    }
    }

    2、接口定义:

    /// <summary>
    /// 定义查询接口。
    /// </summary>
    public interface IQueryParams
    {
    /// <summary>
    /// 参数
    /// </summary>
    QueryParams Parameters{get;}
    }

    3、查询页面继承IQueryParams接口(QueryPage.aspx):

    /// <summary>
    ///查询页面,继承接口
    /// </summary>
    public class QueryPage : System.Web.UI.Page, IQueryParams
    {
    protected System.Web.UI.WebControls.TextBox txtStaDate;
    protected System.Web.UI.WebControls.TextBox txtEndDate;
    private QueryParams queryParams;
       ...
    /// <summary>
    /// 结果页面用到的参数
    /// </summary>
       public QueryParams Parameters
    {
    get
    {
    return queryParams;
    }
    }
    ....
    private void btnEnter_Click(object sender, System.EventArgs e)
    {
    //赋值
    queryParams = new QueryParams();
    queryParams.StaDate = this.txtStaDate.Text;
    queryParams.EndDate = this.txtEndDate.Text
    Server.Transfer("ResultPage.aspx");
    }
    }

    4、别外的页面也如此设置

    5、接收页面(ResultPage.aspx):

    public class ResultPage : System.Web.UI.Page
    {
       private void Page_Load(object sender, System.EventArgs e)
       {
    QueryParams queryParams = new QueryParams();
    IQueryParams queryInterface;
    //实现该接口的页面
    if( Context.Handler is IQueryParams)
    {
    queryInterface = ( IQueryParams )Context.Handler;
    queryParams = queryInterface.Parameters;
    }
    Response.Write( "StaDate:" );
    Response.Write( queryParams.StaDate );
    Response.Write( "<br/>EndDate:" );
    Response.Write( queryParams.EndDate );
      }
    }

  • 相关阅读:
    动态规划解决数字三角形问题
    动态规划,贪心,分治
    7-3 两个有序序列的中位数 (20分) log n的解法
    二分查找 单峰数组中的最大值 O(log n)
    数据库连接池 C3P0和 Druid
    SQL注入问题
    MATLAB spectrogram命令
    JDBC工具类
    Egret--拼接Rect实现用于新手引导的扣洞
    egrte-取消居中约束
  • 原文地址:https://www.cnblogs.com/mahaisong/p/2054327.html
Copyright © 2020-2023  润新知