第一种方法:
通过URL链接地址传递
end.a x:
protected void Button1_Click(object sender, EventArgs e)
{
Request.Redirect("Default2.a x?username=honge");
}
receive.a x:
tring username = Request.QueryString["username"];
这样可以得到参数值。
第二种方法:
通过post方式。
send.a x
<form id="form1" runat=" erver" action="receive.a x" method=post>
<div>
<a :Button ID=" utton1" runat=" erver" OnClick=" utton1_Click" Text=" utto quot; />
<a :TextBox ID="username" runat=" erver" gt lt;/a :TextBox>
</div>
</form>
receive.a x
string username = Ruquest.Form["receive"];
第三种方法:
通过se ion
send.a x:
protected void Button1_Click(object sender, EventArgs e)
{
Se ion["username"] = "honge"
Request.Redirect("Default2.a x");
}
receive.a x:
tring username = Se ion["username"];
这样可以得到参数值。
第四种方法:
通过A lication
send.a x:
protected void Button1_Click(object sender, EventArgs e)
{
A lication["username"] = "honge"
Request.Redirect("Default2.a x");
}
receive.a x:
tring username = A lication["username"];
这样可以得到参数值。
第五种方法:
通过Server.Tra fer
send.a x:
public string Name
{
get {
return "honge"
}
}
protected void Button1_Click(object sender, EventArgs e)
{
Server.Tra fer("Default2.a x");
}
receive.a x:
send d = Context.Handler as send ;
if (d != null)
{
Re o e.Write(d.Name);这样可以得到参数值。
}
如果在a .net 2.0中还可以这样用:通过Previou age
Previou age d = Context.Handler as Previou age ;
if (d != null)
{
Re o e.Write(d.Name);这样可以得到参数值。
}
也可以这样用:
send.a x:
<a :Button ID=" t ubmit" runat=" erver" PostBackUrl="~/reveive.a x" Text=" ubmit" />
receive.a x:
<%@ Previou ageType VirtualPath="~/Default.a x" %>
string name = Previou age.Name;这样可以得到参数值。
如果你的页面中用到了MasterPage的话 Server.Tra fer 传递的 Previou age就无效了,不知道这是什么原因.所以在用到MasterPage的话,最好用Se ion或是Context.Items["username"]来实现.
使用QueryString
使用QuerySting在页面间传递值已经是一种很老的机制了,这种方法的主要优点是实现起来非常简单,然而它的缺点是传递的值是会显示在浏览器的地址栏上的(不安全),同时又不能传递对象,但是在传递的值少而安全性要求不高的情况下,这个方法还是一个不错的方案。使用这种方法的步骤如下:
1、使用控件创建web表单(form)
2、创建可以返回表单的按钮和链接按钮
3、在按钮或链接按钮的单击事件里创建一个保存URL的字符变量
4、在保存的URL里添加QueryString参数
5、使用Re o e.Redirect重定向到上面保存的URL
下面的代码片断演示了如何实现这个方法:
源页面代码:
private void Button1_Click
(object sender, System.EventArgs e)
{
string url;
url="anotherwebform.a x?name=" + TextBox1.Text + " am email=" + TextBox2.Text;
Re o e.Redirect(url);
}
目标页面代码:
private void Page_Load
(object sender, System.EventArgs e)
{
Label1.Text=Request.QueryString[" ame"];
Label2.Text=Request.QueryString["email"];
}
使用Se ion变量
使用Se ion变量是可以在页面间传递值的的另一种方式,在本例中我们把控件中的值存在Se ion变量中,然后在另一个页面中使用它,以不同页面间实现值传递的目的。但是,需要注意的是在Se ion变量存储过多的数据会消耗比较多的服务器资源,在使用se ion时应该慎重,当然了,我们也应该使用一些清理动作来去除一些不需要的se ion来降低资源的无谓消耗。使用Se ion变量传递值的一般步骤如下:
1、在页面里添加必要的控件
2、创建可以返回表单的按钮和链接按钮
3、在按钮或链接按钮的单击事件里,把控件的值添加到se ion变量里
4、使用Re o e.Redirect方法重定向到另一个页面
5、在另一个页面提取se ion的值,在确定不需要使用该se ion时,要显式清除它
下面的代码片断演示了如何实现这个方法:
源页面代码:
private void Button1_Click
(object sender, System.EventArgs e)
{
file://textbox1 and textbox2 are webform
file://controls
Se ion[" ame"]=TextBox1.Text;
Se ion["email"]=TextBox2.Text;
Server.Tra fer("anotherwebform.a x");
}
目标页面代码:
private void Page_Load
(object sender, System.EventArgs e)
{
Label1.Text=Se ion[" ame"].ToString();
Label2.Text=Se ion["email"].ToString();
Se ion.Remove(" ame");
Se ion.Remove("email");
}
使用Server.Tra fer
这个方法相比上面介绍的方法稍微复杂一点,但在页面间值传递中却是特别有用的,使用该方法你可以在另一个页面以对象属性的方式来存取显露的值,当然了,使用这种方法,你需要额外写一些代码以创建一些属性以便可以在另一个页面访问它,但是,这个方式带来的好处也是显而易见的。总体来说,使用这种方法是简洁的同时又是面向对象的。使用这种方法的整个过程如下:
1、在页面里添加必要的控件
2、创建返回值的Get属性过程
3、创建可以返回表单的按钮和链接按钮
4、在按钮单击事件处理程序中调用Server.Tra fer方法转移到指定的页面
5、在第二个页面中,我们就可以使用Context.Handler属性来获得前一个页面实例对象的引用,通过它,就可以使用存取前一个页面的控件的值了
以下代码综合实现上述步骤过程的代码:
源页面代码:
把以下的代码添加到页面中
public string Name
{
get
{
return TextBox1.Text;
}
}
public string EMail
{
get
{
return TextBox2.Text;
}
}
然后调用Server.Tra fer方法
private void Button1_Click
(object sender, System.EventArgs e)
{
Server.Tra fer("anotherwebform.a x");
}
目标页面代码:
private void Page_Load
(object sender, System.EventArgs e)
{
file://create i tance of source web form
WebForm1 wf1;
file://get reference to current handler i tance
wf1=(WebForm1)Context.Handler;
Label1.Text=wf1.Name;
Label2.Text=wf1.EMail;
}
总结
本文讲述了使用不同的方法实现了A .NET页面间值传递,这三种方法是:QueryString,Se ion和Server.Tra fer,我们应该反覆体会几种方法的异同。我希望本文能给你有用的助益,直到在你的代码中运用自如!
相关文章
[错误报告] [推荐] [收藏] [打印] [关闭] [返回顶部]
RSS订阅
已有