1、目前在ASP.NET中頁面傳值共有這麼幾種方式:
1.Response.Redirect("http://www.hao123.com",false);
目標頁面和原頁面能夠在2個服務器上,可輸入網址或相對路徑。後面的bool值爲是否中止執行當前頁。
跳轉向新的頁面,原窗口被代替。
瀏覽器中的URL爲新路徑。
Response.Redirect方法致使瀏覽器連接到一個指定的URL。當Response.Redirect()方法被調用時,它會建立一個應答,應答頭中指出了狀態代碼302(表示目標已經改變)以及新的目標URL。瀏覽器從服務器收到該應答,利用應答頭中的信息發出一個對新URL的請求。這就是說,使用Response.Redirect方法時重定向操做發生在客戶端,總共涉及到兩次與服務器的通訊(兩個來回):第一次是對原始頁面的請求,獲得一個302應答,第二次是請求302應答中聲明的新頁面,獲得重定向以後的頁面。
2.Server.Transfer("Default2.aspx?name=zhangsan",true);
目標頁面和原頁面能夠在同一個服務器上。
跳轉向新的頁面,原窗口被代替。
瀏覽器中的URL爲原路徑不變。
默認狀況下,Server.Transfer方法不會把表單數據或查詢字符串從一個頁面傳遞到另外一個頁面,但只要把該方法的第二個參數設置成True,就能夠保留第一個頁面的表單數據和查詢字符串。同時,使用Server.Transfer時應注意一點:目標頁面將使用原始頁面建立的應答流,這致使ASP.NET的機器驗證檢查(Machine Authentication Check,MAC)認爲新頁面的ViewState已被篡改。所以,若是要保留原始頁面的表單數據和查詢字符串集合,必須把目標頁面Page指令的EnableViewStateMac屬性設置成False。
3.Server.Execute("Default5.aspx?address=beijing);
目標頁面和原頁面能夠在同一個服務器上。
跳轉向新的頁面,再跳轉會原頁面。
瀏覽器中的URL爲原路徑不變。
當指定的ASPX頁面執行完畢,控制流程從新返回原頁面發出Server.Execute調用的位置。
這種頁面導航方式相似於針對ASPX頁面的一次函數調用,被調用的頁面可以訪問發出調用頁面的表單數據和查詢字符串集合,因此要把被調用頁面Page指令的EnableViewStateMac屬性設置成False。
4.Response.Write("<script language='javascript'>window.open('aaa.aspx');</script>");
目標頁面和原頁面能夠在2個服務器上,可輸入網址或相對路徑。
原窗口保留,另外新增一個新頁面。
javascript
5.Response.Write("<script language='javascript'>window.location='Default2.aspx'</script>");
打開新的頁面,原窗口被代替。
6.Response.Write("<script>window.showModalDialog('Default2.aspx')</script>");
7.Response.Write("<script>window.showModelessDialog('Default2.aspx')</script>");
(一)、showModalDialog和showModelessDialog有什麼不一樣?
showModalDialog:被打開後就會始終保持輸入焦點。除非對話框被關閉,不然用戶沒法切換到主窗口。相似alert的運行效果。
showModelessDialog:被打開後,用戶能夠隨機切換輸入焦點。對主窗口沒有任何影響(最可能是被擋住一下而以。:P)
(二)、怎樣才讓在showModalDialog和showModelessDialog的超鏈接不彈出新窗口?
在被打開的網頁里加上<base target="_self">就能夠了。這句話通常是放在<html>和<body>之間的。
同時新打開兩個頁面
<input type="button" value="button" onclick="window.open('1.aspx');window.open('2.aspx');" />
2、若是在兩個頁面間須要大量的參數要傳傳遞,如數據查詢等頁面時,用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;
...
/// <summary>
/// 開始時間
/// </summary>
public string StaDate
{
get{ return this.txtStaDate.Text;}
set{this.txtStaDate.Text = value;}
}
/// <summary>
/// 結束時間
/// </summary>
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( "<br/>EndDate:" );
Response.Write( queryPage.EndDate );
}
}
3、若是有許多查詢頁面共用一個結果頁面的設置方法:
在這種方式中關鍵在於「 QueryPage queryPage = ( QueryPage )Context.Handler; 」的轉換,只有轉換不依賴於特定的頁面時便可實現。
若是讓全部的查詢頁面都繼承一個接口,在該接口中定義一個方法,該方法的惟一做用就是讓結果頁面得到構建結果時所需的參數,就可實現多頁面共享一個結果頁面操做!
一、先定義一個類,用該類放置全部查詢參數:
/// <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;}
}
三、查詢頁面繼承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");
}
}
四、別外的頁面也如此設置
五、接收頁面(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( "<br/>EndDate:" );
Response.Write( queryParams.EndDate );
}
}
.html