在ASP
NET應用中
Web表單之間的導航有多種方式
用超級鏈接
用Response
Redirect
用Server
Transfer
或者用Server
Execute
本文將分析這四種導航方式的異同及其優缺點
幫助你選擇最佳的導航方式
一超級鏈接
從一個表單進入另一個表單最簡單的方式是使用HTML超級鏈接控件在Web表單中使用超級鏈接的HTML代碼類如
復制代碼 代碼如下:
<a href="WebForm
aspx">進入表單
</a>
當用戶點擊該超級鏈接WebFormaspx執行並將結果發送到浏覽器超級鏈接導航方式幾乎可用於任何地方包括HTML頁面和普通的ASP頁面ASPNET還提供了另一種可替換使用的方法即HyperLink服務器控件
復制代碼 代碼如下:
<form id="Form
" method="post" runat="server">
<asp:HyperLink id="HyperLink
" runat="server"
NavigateUrl="WebForm
aspx">進入表單
</asp:HyperLink>
</form>
上 述HTML代碼的運行結果和第一個例子相同因為ASPNET把HyperLink Web服務器控件視為一個HTML超級鏈接控件但兩者有一點重要的區別HyperLink Web服務器控件可以在服務器端編程具體地說可以在程序代碼中改變它的NavigateUrl屬性從而允許構造出具體目標可根據應用的當前狀態動態 變化的超級鏈接例如
復制代碼 代碼如下:
Private Sub Button
_Click( _
ByVal sender As System
Object
_
ByVal e As System
EventArgs) _
Handles Button
Click
HyperLink
NavigateUrl = "WebForm
aspx"
End Sub
這段代碼執行後如果用戶點擊鏈接他看到的將是WebFormaspx而不是WebFormaspx
二用程序控制重定向
雖 然超級鏈接能夠從一個頁面導航到另一個頁面但這種導航方式是完全由用戶控制的有些時候我們可能要用代碼來控制整個導航過程包括何時轉到另一個頁 面在這些場合ASPNET有三種不同的方式可以達到相似的目的調用Response對象的Redirect方法調用Server對象的 Transfer或Execute方法這三種導航方式的行為基本相似但也有區別
ResponseRedirect
ResponseRedirect 方法導致浏覽器鏈接到一個指定的URL當ResponseRedirect()方法被調用時它會創建一個應答應答頭中指出了狀態代碼(表示 目標已經改變)以及新的目標URL浏覽器從服務器收到該應答利用應答頭中的信息發出一個對新URL的請求
這就是說使用ResponseRedirect方法時重定向操作發生在客戶端總共涉及到兩次與服務器的通信(兩個來回)第一次是對原始頁面的請求得到一個應答第二次是請求應答中聲明的新頁面得到重定向之後的頁面
ServerTransfer
ServerTransfer方法把執行流程從當前的ASPX文件轉到同一服務器上的另一個ASPX頁面調用ServerTransfer時當前的ASPX頁面終止執行執行流程轉入另一個ASPX頁面但新的ASPX頁面仍使用前一ASPX頁面創建的應答流
如果用ServerTransfer方法實現頁面之間的導航浏覽器中的URL不會改變因為重定向完全在服務器端進行浏覽器根本不知道服務器已經執行了一次頁面變換
默認情況下ServerTransfer方法不會把表單數據或查詢字符串從一個頁面傳遞到另一個頁面但只要把該方法的第二個參數設置成True就可以保留第一個頁面的表單數據和查詢字符串
同 時使用ServerTransfer時應注意一點目標頁面將使用原始頁面創建的應答流這導致ASPNET的機器驗證檢查(Machine Authentication CheckMAC)認為新頁面的ViewState已被篡改因此如果要保留原始頁面的表單數據和查詢字符串集合必須把目標頁面Page指令的 EnableViewStateMac屬性設置成False
ServerExecute
ServerExecute方法允許當前的ASPX頁面執行一個同一Web服務器上的指定ASPX頁面當指定的ASPX頁面執行完畢控制流程重新返回原頁面發出ServerExecute調用的位置
這種頁面導航方式類似於針對ASPX頁面的一次函數調用被調用的頁面能夠訪問發出調用頁面的表單數據和查詢字符串集合所以要把被調用頁面Page指令的EnableViewStateMac屬性設置成False
默 認情況下被調用頁面的輸出追加到當前應答流但是ServerExecute方法有一個重載的方法允許通過一個TextWriter對象(或者它 的子對象例如StringWriter對象)獲取被調用頁面的輸出而不是直接追加到輸出流這樣在原始頁面中可以方便地調整被調用頁面輸出結果的位 置
為說明其工作過程下面我們創建一個Web表單放入一個按鈕控件(Button)和一個文本控件(Literal)在設計界面中轉入代碼視圖加入一個SystemIO名稱空間的Imports語句然後加入用戶點擊按鈕時執行的代碼
復制代碼 代碼如下:
Private Sub Button
_Click( _
ByVal sender As System
Object
_
ByVal e As System
EventArgs) _
Handles Button
Click
Dim sw As StringWriter = New StringWriter()
Server
Execute("WebForm
aspx"
sw)
Literal
Text = sw
ToString()
End Sub
然後為同一個Web應用創建第二個頁面WebFormaspx轉入該頁面的HTML視圖修改其Page指令禁止ViewState檢查
復制代碼 代碼如下:
<%@ Page Language="vb" AutoEventWireup="false" Codebehind="WebForm
aspx
vb"
Inherits="Navigate
WebForm
" EnableViewStateMac="false"%>
再轉到設計視圖為第二個頁面增加一些控件接下來把第一個頁面設置成默認頁面啟動應用點擊按鈕WebForm的控件將顯示在WebForm中放置Literal按鈕的地方注意頁面標題和URL仍舊顯示原始頁面WebForm
用 ServerTransfer或ServerExecute方法實現導航時還要注意一點最後得到的頁面可能不是合法的HTML頁面因為最終返回 給客戶端的頁面可能包含多個<HTML>和<BODY>等標記IE浏覽器看來能夠容忍並正確處理這類情形但如果用戶要用到其 他的浏覽器最好仔細測試一下
三比較與選擇
既然從一個頁面導航到另一個頁面的辦法有這麼多應該如何選擇最佳的導航方式呢?下面是一些需要考慮的因素
·如果要讓用戶來決定何時轉換頁面以及轉到哪一個頁面超級鏈接最適合
·如果要用程序來控制轉換的目標但轉換的時機由用戶決定使用Web服務器的HyperLink控件動態設置其NavigateUrl屬性
·如果要把用戶連接到另一台服務器上的資源使用ResponseRedirect
·用ResponseRedirect把用戶連接到非ASPX的資源例如HTML頁面
·如果要將查詢字符串作為URL的一部分保留使用ResponseRedirect
·如果要將執行流程轉入同一Web服務器的另一個ASPX頁面應當使用ServerTransfer而不是ResponseRedirect因為ServerTransfer能夠避免不必要的網絡通信從而獲得更好的性能和浏覽效果
·如果要捕獲一個ASPX頁面的輸出結果然後將結果插入另一個ASPX頁面的特定位置則使用ServerExecute
·如果要確保HTML輸出合法請使用ResponseRedirect不要使用ServerTransfer或ServerExecute方法
From:http://tw.wingwit.com/Article/program/net/201311/14374.html