ASP.NET中页面传值


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

1、表单提交,

1  <form action= "target.aspx" method = "post" name = "form1">
2 <input name = "param1" value = "1111"/>
3 <input name = "param2" value = "2222"/>
4 </form>
5 ....
6 form1.submit();
7 ....

此种方在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):

 1    public class QueryPage : System.Web.UI.Page
2 {
3 protected System.Web.UI.WebControls.TextBox txtStaDate;
4 protected System.Web.UI.WebControls.TextBox txtEndDate;
5 ...
6 /// <summary>
7 /// 开始时间
8 /// </summary>
9 public string StaDate
10 {
11 get{ return this.txtStaDate.Text;}
12 set{this.txtStaDate.Text = value;}
13 }
14 /// <summary>
15 /// 结束时间
16 /// </summary>
17 public string EndDate
18 {
19 get{ return this.txtEndDate.Text;}
20 set{this.txtEndDate.Text = value;}
21 }
22 ....
23 private void btnEnter_Click(object sender, System.EventArgs e)
24 {
25 Server.Transfer("ResultPage.aspx");
26 }
27 }
28
29 在显示查询结果页面(ResultPage.aspx):
30
31 public class ResultPage : System.Web.UI.Page
32 {
33 private void Page_Load(object sender, System.EventArgs e)
34 {
35 //转换一下即可获得前一页面中输入的数据
36 QueryPage queryPage = ( QueryPage )Context.Handler;
37 Response.Write( "StaDate:" );
38 Response.Write( queryPage.StaDate );
39 Response.Write( "<br/>EndDate:" );
40 Response.Write( queryPage.EndDate );
41 }
42 }


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

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

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

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

 1 /// <summary>
2 /// 结果页面中要用到的值
3 /// </summary>
4 public class QueryParams
5 {
6 private string staDate;
7 private string endDate;
8 /// <summary>
9 /// 开始时间
10 /// </summary>
11 public string StaDate
12 {
13 get{ return this.staDate;}
14 set{this.staDate = value;}
15 }
16 /// <summary>
17 /// 结束时间
18 /// </summary>
19 public string EndDate
20 {
21 get{ return this.endDate;}
22 set{this.endDate = value;}
23 }
24 }

2、接口定义:

 1 /// <summary>
2 /// 定义查询接口。
3 /// </summary>
4 public interface IQueryParams
5 {
6 /// <summary>
7 /// 参数
8 /// </summary>
9 QueryParams Parameters{get;}
10 }

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

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

 1 /// <summary>
2 ///查询页面,继承接口
3 /// </summary>
4 public class QueryPage : System.Web.UI.Page, IQueryParams
5 {
6 protected System.Web.UI.WebControls.TextBox txtStaDate;
7 protected System.Web.UI.WebControls.TextBox txtEndDate;
8 private QueryParams queryParams;
9 ...
10 /// <summary>
11 /// 结果页面用到的参数
12 /// </summary>
13 public QueryParams Parameters
14 {
15 get
16 {
17 return queryParams;
18 }
19 }
20 ....
21 private void btnEnter_Click(object sender, System.EventArgs e)
22 {
23 //赋值
24 queryParams = new QueryParams();
25 queryParams.StaDate = this.txtStaDate.Text;
26 queryParams.EndDate = this.txtEndDate.Text
27 Server.Transfer("ResultPage.aspx");
28 }
29 }

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

 1 public class ResultPage : System.Web.UI.Page
2 {
3 private void Page_Load(object sender, System.EventArgs e)
4 {
5 QueryParams queryParams = new QueryParams();
6 IQueryParams queryInterface;
7 //实现该接口的页面
8 if( Context.Handler is IQueryParams)
9 {
10 queryInterface = ( IQueryParams )Context.Handler;
11 queryParams = queryInterface.Parameters;
12 }
13 Response.Write( "StaDate:" );
14 Response.Write( queryParams.StaDate );
15 Response.Write( "<br/>EndDate:" );
16 Response.Write( queryParams.EndDate );
17 }
18 }

优质内容筛选与推荐>>
1、web开发的浏览器(工具)插件
2、SSD在SQLServer中的应用
3、LightOj1385 - Kingdom Division(数学几何题)
4、MySQL数据库增删改查SQL语句(2018整理集合大全)
5、等待是另一种形式的行走


长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号





    联系我们

    欢迎来到TinyMind。

    关于TinyMind的内容或商务合作、网站建议,举报不良信息等均可联系我们。

    TinyMind客服邮箱:support@tinymind.net.cn