• 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);

        }

    }

  • 相关阅读:
    Linux kernel AACRAID Driver Compat IOCTL 本地安全绕过漏洞
    WordPress Contact Form 7插件任意文件上传漏洞
    文件上传
    Po类设计
    MySQL 表设计
    Mybatis——更新DB表的字段时,应该注意的点
    分页——为Mybatis配置PageHelper
    SpringAOP配置与使用(示例)
    日志问题
    为一台全新的电脑构建JavaEE开发环境
  • 原文地址:https://www.cnblogs.com/Shirly-Zhang/p/5275584.html
Copyright © 2020-2023  润新知