一、使用Querystring 
Querystring是一种非常简单的传值方式,其缺点就是会把要传送的值显示在浏览器的地址栏中,并且在此方法中不能够传递对象。如果你想传递一个安全性不是那么太重要或者是一个简单的数值时,用此方法最好不过了。下面通过一个小例子来完成传值工作,步骤如下: 
1、创建一个web form 
2、在新建的web form中放置一个button1,在放置两个TextBox1,TextBox2 
3、为button按钮创建click事件 
代码如下: 
private void Button1_Click  
(object sender, System.EventArgs e)  
{  
 string url;  
 url="webform2.aspx?name=" +  
  TextBox1.Text + "&email=" +  
  TextBox2.Text;  
 Response.Redirect(url);  
}  
4、新建一个目标页面命名为webform2  
5、在webform2中放置两个Label1,Label2  
在webform2的Page_Load中添加如下代码:  
private void Page_Load  
(object sender, System.EventArgs e)  
{  
 Label1.Text=Request.QueryString["name"];  
 Label2.Text=Request.QueryString["email"];  
}  
运行,即可看到传递后的结果了。  
 
二、使用Session变量  
使用Session变量传值是一种最常见的方式了,此中方式不仅可以把值传递到下一个页面,还可以交叉传递到多个页面,直至把Session变量的值removed后,变量才会消失。举个例子看看:  
1、创建一个web form  
2、在新建的web form中放置一个button1,在放置两个TextBox1,TextBox2  
3、为button按钮创建click事件  
代码如下:

引用内容:
  
private void Button1_Click  
(object sender, System.EventArgs e)  
{  
        Session["name"]=TextBox1.Text;  
 Session["email"]=TextBox2.Text;  
 Response.Redirect("webform2.aspx");  
}  
4、新建一个目标页面命名为webform2  
5、在webform2中放置两个Label1,Label2  
在webform2的Page_Load中添加如下代码:  
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、创建一个web form  
2、在新建的web form中放置一个button1,在放置两个TextBox1,TextBox2  
3、为button按钮创建click事件  
代码如下:

引用内容:
 
private void Button1_Click  
(object sender, System.EventArgs e)  
{  
 Server.Transfer("webform2.aspx");  
}  
4、创建过程来返回TextBox1,TextBox2控件的值代码如下:  
public string Name  
{  
 get  
 {  
  return TextBox1.Text;  
 }  
}  
public string EMail  
{  
 get  
 {  
  return TextBox2.Text;  
 }  
}

5、新建一个目标页面命名为webform2  
6、在webform2中放置两个Label1,Label2  
在webform2的Page_Load中添加如下代码:  
private void Page_Load  
(object sender, System.EventArgs e)  
{ //创建原始窗体的实例  
 WebForm1 wf1;  
 //获得实例化的句柄  
 wf1=(WebForm1)Context.Handler;  
 Label1.Text=wf1.Name;  
 Label2.Text=wf1.EMail;}

浅谈Asp.Net中的几种传值方式的更多相关文章

  1. Asp.Net中的三种分页方式

    Asp.Net中的三种分页方式 通常分页有3种方法,分别是asp.net自带的数据显示空间如GridView等自带的分页,第三方分页控件如aspnetpager,存储过程分页等. 第一种:使用Grid ...

  2. 浅谈SQL Server中的三种物理连接操作

    简介 在SQL Server中,我们所常见的表与表之间的Inner Join,Outer Join都会被执行引擎根据所选的列,数据上是否有索引,所选数据的选择性转化为Loop Join,Merge J ...

  3. 浅谈SQL Server中的三种物理连接操作(HASH JOIN MERGE JOIN NESTED LOOP)

    简介 在SQL Server中,我们所常见的表与表之间的Inner Join,Outer Join都会被执行引擎根据所选的列,数据上是否有索引,所选数据的选择性转化为Loop Join,Merge J ...

  4. 浅谈SQL Server中的三种物理连接操作(Nested Loop Join、Merge Join、Hash Join)

    简介 在SQL Server中,我们所常见的表与表之间的Inner Join,Outer Join都会被执行引擎根据所选的列,数据上是否有索引,所选数据的选择性转化为Loop Join,Merge J ...

  5. iOS 浅谈MVC设计模式及Controllers之间的传值方式

    1.简述你对MVC的理解? MVC是一种架构设计.它考虑了三种对象:Model(模型对象).View(试图对象).Controller(试图控制器) (1)模型:负责存储.定义.操作数据 (2)视图: ...

  6. 浅谈ASP.net中的DataSet对象

    在我们对数据库进行操作的时候,总是先把数据从数据库取出来,然后放到一个"容器"中,再通过这个"容器"取出数据显示在前台,而充当这种容器的角色中当属DataSet ...

  7. 浅谈[^>]在正则中的2种用法

    /^A/会匹配"An e"中的A,但是不会匹配"ab A"中的A,此时^A的意思是“匹配开头的A” /[^a-z\s]/会匹配"my 3 sister ...

  8. Asp.Net中的三种分页方式总结

    本人ASP.net初学,网上找了一些分页的资料,看到这篇文章,没看到作者在名字,我转了你的文章,只为我可以用的时候方便查看,2010的文章了,不知道这技术是否过期. 以下才是正文 通常分页有3种方法, ...

  9. 浅谈Entity Framework中的数据加载方式

    如果你还没有接触过或者根本不了解什么是Entity Framework,那么请看这里http://www.entityframeworktutorial.net/EntityFramework-Arc ...

随机推荐

  1. c++中获得对象类型 typeid 与 type_info

    复杂部分略去,摘录要素如下: 1.typeid是C++的关键字之一,等同于sizeof这类的操作符. 2.typeid操作符的返回结果是名为type_info的标准库类型的对象的引用(在头文件type ...

  2. Prometheus PromSQL 常用资源

    Prometheus PromSQL 常用资源 PromSQL 使用 运算乘:*除:/加:+减:- 函数 sum() 函数:求出找到所有value的值 irate() 函数:统计平均速率 by (标签 ...

  3. EF连接mysql,出现A call to SSPI failed错误,解决办法

    我的使用场景是用EF连接AWS的mysql RDS,会偶发性的出现A call to SSPI failed错误, System.AggregateException: One or more err ...

  4. 练手WPF(一)——模拟时钟与数字时钟的制作(上)

    一.Visual Studio创建一个WPF项目. 简单调整一下MainWindow.xaml文件.主要使用了两个Canvas控件,分别用于显示模拟和数字时钟,命名为AnalogCanvas.digi ...

  5. oracle 获取表\视图的列名

     select COLUMN_NAME FROM user_col_comments WHERE TABLE_NAME='视图名'  select COLUMN_NAME from all_tab_c ...

  6. 如何在windows 7 上使用docker

    在window7上面本来是支持使用docker的, 但是我们可以通过安装docker toolbox来实现在windows7上使用docker. 参考网址: https://docs.docker.c ...

  7. EFCore 2.0的IEntityTypeConfiguration<TEntity>的使用!

    通过新建一个类来实现  IEntityTypeConfiguration 这个接口,将EFCore中的实体配置写在单独的配置类中,便于修改和维护. OnModelCreating代码: protect ...

  8. go 中string[0]到底是rune还是byte?

    好像没区别,对吧? 来看个全面的对比: package main import ( "fmt" "reflect") func main(){ asci:=&q ...

  9. Haskell路线

    @ 知乎 @ <I wish i have learned haskell> ———— 包括: Ranks, forall, Monad/CPS,  monadic parser, FFI ...

  10. 图示详解BERT模型的输入与输出

    一.BERT整体结构 BERT主要用了Transformer的Encoder,而没有用其Decoder,我想是因为BERT是一个预训练模型,只要学到其中语义关系即可,不需要去解码完成具体的任务.整体架 ...