当前位置: 首页 > 编程笔记 >

详述ASP.Net中页面之间传参方法

松俊才
2023-03-14
本文向大家介绍详述ASP.Net中页面之间传参方法,包括了详述ASP.Net中页面之间传参方法的使用技巧和注意事项,需要的朋友参考一下

ASP.NET提供了卓越的事件驱动编程模型,让开发者简化了应用程序的总体设计,但是这个也造成了它固有的一些问题,例如,使用传统的ASP里,我们可以通过使用POST方法很容易地实现页面间传递值,同样的事情,在使用事件驱动编程模型的ASP.NET就不是那么容易了,当然了,我们仍然有一些方法可以实现同样的功能。

本文将试着使用不同的可能的方法来解决这个问题,但可以预见是,本文将包含使用querystring,session变量以及server.Transfer方法来实现页面间的值传递。

使用QueryString

使用QuerySting在页面间传递值已经是一种很老的机制了,这种方法的主要优点是实现起来非常简单,然而它的缺点是传递的值是会显示在浏览器的地址栏上的(不安全),同时又不能传递对象,但是在传递的值少而安全性要求不高的情况下,这个方法还是一个不错的方案。

使用这种方法的步骤如下:

  1. 使用控件创建web表单(form)
  2. 创建可以返回表单的按钮和链接按钮
  3. 在按钮或链接按钮的单击事件里创建一个保存URL的字符变量
  4. 在保存的URL里添加QueryString参数
  5. 使用Response.Redirect重定向到上面保存的URL 下面的代码片断演示了如何实现这个方法:

源页面代码:

private void Button1_Click (object sender, System.EventArgs e) 
{ 
string url; 
url="anotherwebform.aspx?name=" + TextBox1.Text + "&email=" + TextBox2.Text; 
Response.Redirect(url); 
} 

目标页面代码:

private void Page_Load (object sender, System.EventArgs e) 
{ 
Label1.Text=Request.QueryString["name"]; 
Label2.Text=Request.QueryString["email"]; 
} 

使用Session变量

使用Session变量是可以在页面间传递值的的另一种方式,在本例中我们把控件中的值存在Session变量中,然后在另一个页面中使用它,以不同页面间实现值传递的目的。但是,需要注意的是在Session变量存储过多的数据会消耗比较多的服务器资源,在使用session时应该慎重,当然了,我们也应该使用一些清理动作来去除一些不需要的session来降低资源的无谓消耗。

使用Session变量传递值的一般步骤如下:

  1. 在页面里添加必要的控件
  2. 创建可以返回表单的按钮和链接按钮  
  3. 在按钮或链接按钮的单击事件里,把控件的值添加到session变量里
  4. 使用Response.Redirect方法重定向到另一个页面
  5. 在另一个页面提取session的值,在确定不需要使用该session时,要显式清除它 下面的代码片断演示了如何实现这个方法:

源页面代码:

private void Button1_Click (object sender, System.EventArgs e) 
{ 
//textbox1 and textbox2 are webform controls 
Session["name"]=TextBox1.Text; 
Session["email"]=TextBox2.Text; 
Server.Transfer("anotherwebform.aspx"); 
} 

目标页面代码:

private void Page_Load (object sender, System.EventArgs e) 
{ 
Label1.Text=Session["name"].ToString(); 
Label2.Text=Session["email"].ToString(); 
Session.Remove("name"); 
Session.Remove("email"); 
} 

使用Server.Transfer

这个方法相比上面介绍的方法稍微复杂一点,但在页面间值传递中却是特别有用的,使用该方法你可以在另一个页面以对象属性的方式来存取显露的值,当然了,使用这种方法,你需要额外写一些代码以创建一些属性以便可以在另一个页面访问它,但是,这个方式带来的好处也是显而易见的。总体来说,使用这种方法是简洁的同时又是面向对象的。

使用这种方法的整个过程如下:

  1. 在页面里添加必要的控件
  2. 创建返回值的Get属性过程
  3. 创建可以返回表单的按钮和链接按钮
  4. 在按钮单击事件处理程序中调用Server.Transfer方法转移到指定的页面
  5. 在第二个页面中,我们就可以使用Context.Handler属性来获得前一个页面实例对象的引用,通过它,就可以使用存取前一个页面的控件的值了 以下代码综合实现上述步骤过程的代码: 源页面代码: 把以下的代码添加到页面中
public string Name 
{ 
get { return TextBox1.Text; } 
} 
public string EMail 
{ 
get { return TextBox2.Text; } 
} 

然后调用Server.Transfer方法

private void Button1_Click (object sender, System.EventArgs e) 
{ 
Server.Transfer("anotherwebform.aspx"); 
} 

目标页面代码

private void Page_Load (object sender, System.EventArgs e) 
{ 
//create instance of source web form 
WebForm1 wf1;  
//get reference to current handler instance 
wf1=(WebForm1)Context.Handler; 
Label1.Text=wf1.Name; 
Label2.Text=wf1.EMail; 
} 

通过本文的对页面之间传递参数几种方法的介绍,希望对你有帮助,也希望多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍列举ASP.NET页面之间传递值的几种方式。 相关面试题,主要包含被问及列举ASP.NET页面之间传递值的几种方式。 时的应答技巧和注意事项,需要的朋友参考一下 答. session(viewstate) 简单,但易丢失 application全局 cookie简单,但可能不支持,可能被伪造 inputttype="hidden" 简单,可能被伪造 url参数 简单,QueryStr

  • 本文向大家介绍Android intent之间复杂参数传递方法详解,包括了Android intent之间复杂参数传递方法详解的使用技巧和注意事项,需要的朋友参考一下 本文详细讲述了Android intent之间复杂参数传递方法。分享给大家供大家参考,具体如下: Intent是Activity与Activity之间,Activity与Service之间传递参数的介质,而这两种通常实现的是Java

  • 在普通的web开发中,参数传递有这么几种形式: url: /another_page?id=3 表单: <form>...</form> 在vuejs中,不会产生表单的提交(这会引起页面的整体刷新). 所以有两种: url . 同传统语言. vuejs 内部的机制.(无法在url 中体现,可以认为是由js代码隐式实现的) 我们用一个实际的例子说明. 我们之前实现了 "博客列表页",接下来我们要实现

  • 问题内容: 我正在尝试在应用程序的结帐过程中在页面之间传递数据,但是它无法正常工作。我已经读了一些书,大多数人建议使用服务,但是唯一的问题是,刷新页面(用户单击刷新或稍后再返回)时,该服务中的所有数据都会消失。这是有道理的,因为服务中的数据并不是永久性的,而是会引起问题。 所以问题是:如何在angularJS中的页面之间传递数据,并且仍然保持页面刷新后传递的数据? 到目前为止,这是我的代码(尝试使

  • 本文向大家介绍详解layui弹窗父子窗口之间传参数的方法,包括了详解layui弹窗父子窗口之间传参数的方法的使用技巧和注意事项,需要的朋友参考一下 本文介绍了layui弹窗父子窗口之间传参数的方法,分享给大家,具体如下: 1、父页面打开子页面并向子页面传参数 2、子页面向父页面传参数并关闭弹窗 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

  • 本文向大家介绍js实现页面a向页面b传参的方法,包括了js实现页面a向页面b传参的方法的使用技巧和注意事项,需要的朋友参考一下 本文为大家分享了js实现页面a向页面b传参的具体方法,供大家参考,具体内容如下 方法一:使用HTML5本地化存储(localStorage) 组件(本地最大能存储5M数据)localStorage是本地永久存储数据,是cookie的优化 方法二:使用cookie将数据存放