查看: 14390|回复: 2
打印 上一主题 下一主题

ASP.NET十分有用的页面间传值方法

[复制链接]
跳转到指定楼层
1#
发表于 2007-9-21 16:25:28 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
台州网址导航
一、目前在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、链接地址传送
接收页面: string str = Request["param1"]
3、Session共享
发送页面:Session("param1") = "1111";  
按收页面  string str = Session("param1").ToString();  
4、Application共享
发送页面: Application("param1") = "1111";   
按收页面: string str = Application("param1").ToString();  Chinaz
此种方法不常使用,因为Application在一个应用程序域范围共享,所有用户可以改变及设置其值,故只应用计数器等需要全局变量的地方。
5、Cookie
6、Response.Redirect()方式
   Response.Redirect("target.aspx?param1=1111?m2=2222")
   接收页面: string str = Request["param1"]
7、Server.Transfer()方式。
   Server.Transfer("target.aspx?param1=1111?m2=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. ///
  7. /// 开始时间
  8. ///
  9. public string StaDate
  10. {
  11. get{ return this.txtStaDate.Text;}
  12. set{this.txtStaDate.Text = value;}
  13. }
  14. ///
  15. /// 结束时间
  16. ///
  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. 在显示查询结果页面(ResultPage.aspx)



  29. 以下为引用的内容:
  30. public class ResultPage : System.Web.UI.Page
  31. {
  32.    private void Page_Load(object sender, System.EventArgs e)
  33.    {
  34. //转换一下即可获得前一页面中输入的数据
  35. QueryPage queryPage = ( QueryPage )Context.Handler;  

  36. Response.Write( "StaDate:" );
  37. Response.Write( queryPage.StaDate );
  38. Response.Write( "
  39. EndDate:" );
  40. Response.Write( queryPage.EndDate );
  41.   }
  42. }  
复制代码
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 转播转播 分享分享 分享淘帖
台州维博网络(www.tzweb.com)专门运用PHP+MYSQL/ASP.NET+MSSQL技术开发网站门户平台系统等。
2#
 楼主| 发表于 2007-9-21 16:26:09 | 只看该作者
台州网址导航
三、如果有许多查询页面共用一个结果页面的设置方法:
    在这种方式中关键在于“ 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;}
}
}

、接口定义:



以下为引用的内容:

/// <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");
}
}
台州维博网络(www.tzweb.com)专门运用PHP+MYSQL/ASP.NET+MSSQL技术开发网站门户平台系统等。
3#
 楼主| 发表于 2007-9-21 16:26:22 | 只看该作者
台州网址导航
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;
} Www~Chinaz~com

Response.Write( "StaDate:" );
Response.Write( queryParams.StaDate );
Response.Write( "<br/>EndDate:" );
Response.Write( queryParams.EndDate );
  }
}



三、本文起因:
      因在工作中要作一个数据查询,参数烦多,原先是用Session传递,用完该Session传来的参数后,还需清理Session,在用Session之前还得判断该Session是否存在,极其烦琐,我想应该还有更简便的方法来实现页面间的参数传递,故上网查找,终于找到这样一种方式来实现页面间的参数传递。  

2007-7-15 13:40 #3
台州维博网络(www.tzweb.com)专门运用PHP+MYSQL/ASP.NET+MSSQL技术开发网站门户平台系统等。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

网站推广
关于我们
  • 台州朗动科技(Tzweb.com)拥有多年开发网站平台系统门户手机客户端等业务的成功经验。主要从事:政企网站,系统平台,微信公众号,各类小程序,手机APP客户端,浙里办微应用,浙政钉微应用、主机域名、虚拟空间、后期维护等服务,满足不同企业公司的需求,是台州地区领先的网络技术服务商!

Hi,扫描关注我

Copyright © 2005-2026 站长论坛 All rights reserved

Powered by 站长论坛 with TZWEB Update Techonolgy Support

快速回复 返回顶部 返回列表