zoukankan
html css js c++ java
(转) 在ASP.NET中页面传值的几种方式
2007
-
04
-
04
09
:05一、目前在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();
此种方法不常使用,因为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):
public
class
QueryPage : System.Web.UI.Page
{
protected
System.Web.UI.WebControls.TextBox txtStaDate;
protected
System.Web.UI.WebControls.TextBox txtEndDate;
/**/
/**/
/**/
///
///
开始时间
///
public
string
StaDate
{
get
{
return
this
.txtStaDate.Text;}
set
{
this
.txtStaDate.Text
=
value;}
}
/**/
/**/
/**/
///
///
结束时间
///
public
string
EndDate
{
get
{
return
this
.txtEndDate.Text;}
set
{
this
.txtEndDate.Text
=
value;}
}
.
private
void
btnEnter_Click(
object
sender, System.EventArgs e)
{
Server.Transfer(
"
ResultPage.aspx
"
);
}
}
在显示查询结果页面(ResultPage.aspx):
public
class
ResultPage : System.Web.UI.Page
{
private
void
Page_Load(
object
sender, System.EventArgs e)
{
//
转换一下即可获得前一页面中输入的数据
QueryPage queryPage
=
( QueryPage )
Context.Handler
;
Response.Write(
"
StaDate:
"
);
Response.Write( queryPage.StaDate );
Response.Write(
"
EndDate:
"
);
Response.Write( queryPage.EndDate );
}
}
三、如果有许多查询页面共用一个结果页面的设置方法:
在这种方式中关键在于“ QueryPage queryPage
=
( QueryPage )
Context.Handler
; ”的转换,只有转换不依赖于特定的页面时即可实现。
如果让所有的查询页面都继承一个接口,在该接口中定义一个方法,该方法的唯一作用就是让结果页面获得构建结果时所需的参数,就可实现多页面共享一个结果页面操作!
1
、先定义一个类,用该类放置所有查询参数:
/**/
/**/
/**/
///
///
结果页面中要用到的值
///
public
class
QueryParams
{
private
string
staDate;
private
string
endDate;
/**/
/**/
/**/
///
///
开始时间
///
public
string
StaDate
{
get
{
return
this
.staDate;}
set
{
this
.staDate
=
value;}
}
/**/
/**/
/**/
///
///
结束时间
///
public
string
EndDate
{
get
{
return
this
.endDate;}
set
{
this
.endDate
=
value;}
}
}
2
、接口定义:
/**/
/**/
/**/
///
///
定义查询接口。
///
public
interface
IQueryParams
{
/**/
/**/
/**/
///
///
参数
///
QueryParams Parameters
{
get
;}
}
3
、查询页面继承IQueryParams接口(QueryPage.aspx):
/**/
/**/
/**/
///
///
查询页面,继承接口
///
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;
/**/
/**/
/**/
///
///
结果页面用到的参数
///
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
"
);
}
}
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;
}
Response.Write(
"
StaDate:
"
);
Response.Write( queryParams.StaDate );
Response.Write(
"
EndDate:
"
);
Response.Write( queryParams.EndDate );
}
}
在调用的页面
<%@
Reference
Page = "WebForm1.aspx" %>
WebForm1 fp=(WebForm1)Context.Handler;
this.TextBox1.Text=fp.name; //name 是第一页的public变量
查看全文
相关阅读:
数据库创建索引的缺点,和什么时候不该创建索引
创建数据库,表,索引,删除索引,查看表中的索引和如何使用表中的索引
java容器中 哪些是线程安全的
java中集合类详解
高并发 问题怎么解决
数据库20个问题(关于事务、存储引擎、索引、悲观锁乐观锁)
数据库事务(什么是事务)
Application对象详解
get和post 两种基本请求方式的区别
BZOJ1003物流運輸 DP + SPFA
原文地址:https://www.cnblogs.com/suneryong/p/730225.html
最新文章
adb -s 设备名 设备名还有非法字符
13常用sql语句
13 获取外部数据库 以及数据库游标适配器(SimpleCursorAdapter)
13 SQLiteOpenHelper SQLiteDatabase详解
13 数据库 总结
ubunut系统清理系统根目录下缓存文件夹.cache超大导致磁盘不足
12 SharedPreferences
12 外部存储和内部存储
12 获取外部存储卡大小
12 PopupWindow
热门文章
word 文献标题自动编号
gvim 安装YouCompleteMe插件
GCC的gcc和g++区别
DXP 快捷键
时间相关
Linux curses库使用
简单实用的makefile
ncurse 笔记
vim中自动格式化代码
让博客园博客自动生成章节目录索引
Copyright © 2011-2022 走看看