成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

ASP.NET跨頁提交功能詳解

開發 后端
本文向您提交AP.NET跨頁提交的方法,作者根據自己的經驗提供了傳統ASP.NET跨頁提交和另一種解決問題的思路。

標準HTML表單(form元素)允許你向另外一個頁面或者應用程序傳遞和發送數據信息,方法是使用表單元素。在ASP.NET 1.x中,網頁則利用投遞機制,把頁面數據提交給該頁本身。下面就讓我們來探討這個新特性:

傳統ASP.NET跨頁提交方法

為了便于比較,我們來回顧網頁傳遞數據的老方法。HTML的表格元素有一個action(動作)屬性,用來指定服務器端哪項資源(所謂資源,是指一個網頁、一段腳本、程序等)來處理這些提交的數據。下面的代碼便是一個樣例。

以下是引用片段:

  1. 〈html〉  
  2. 〈head〉〈title〉Sample HTML form〈/title〉〈/head〉  
  3. 〈body〉  
  4. 〈form name="frmSample" method="post" action="target_url"〉  
  5. 〈input type="text" name="fullname" id="fullname" /〉  
  6. 〈input type="button" name="Submit" value="submit" /〉  
  7. 〈/form〉  
  8. 〈/body〉  
  9. 〈/html〉  

在文本域(名字是fullname)中輸入的值將被提交給表單元素的action屬性指定的頁面或者程序。對于ASP.NET開發者,即使曾經用過標準HTML表單,也是極不多見的。

ASP.NET開發者面對要從一個網頁向另一個網頁傳遞數據信息的任務時,方法選擇的余地是異常廣闊的。它們包括會話變量(session variables)、cookies、querystring 變量、caching(網頁緩存),甚至Server.Transfer方法,但是SP.NET跨頁提交還提供了另外一種選擇。

SP.NET跨頁提交的又一辦法

在設計ASP.NET 2.0的時候,微軟認識到了在網頁間交叉傳遞數據的需求。有了這個意識之后,就為ASP.NET的button(按鈕)控件增加了一項 PostBackUrl屬性。它允許你在用戶提交的時候,指明這張表單和上面的數據送往何方(也就是由PostBackUrl屬性指定的URL值確定)。一般來講,跨頁傳遞是客戶端在后臺使用JavaScript進行傳送的過程。

以下是引用片段:

  1. 〈%@ Page language="vb" %〉  
  2. 〈!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML   
  3. 4.0 Transitional//EN" 〉  
  4. 〈html〉〈head〉  
  5. 〈title〉Cross Postback Example〈/title〉  
  6. 〈/head〉〈body〉  
  7. 〈form id="frmCrossPostback1" method="post"   
  8. runat="server"〉  
  9. 〈asp:Label ID="lblName" runat="server" Text="Name:"〉  
  10. 〈/asp:Label〉  
  11. 〈asp:TextBox ID="txtName" runat="server"〉  
  12. 〈/asp:TextBox〉〈br /〉  
  13. 〈asp:Label ID="lblE-mailAddress" runat="server"   
  14. Text="E-mail:"〉〈/asp:Label〉  
  15. 〈asp:TextBox ID="txtE-mailAddress" runat="server"〉  
  16. 〈/asp:TextBox〉〈br /〉   
  17. 〈asp:Button ID="btnSubmit" runat="server"   
  18. Text="Submit" PostBackUrl="CrossPostback2.aspx" /〉  
  19. 〈/form〉  
  20. 〈/body〉  
  21. 〈/html〉  

ASP.NET頁面擁有兩個文本域(分別表示name(名字)和e-mail(電子郵件)),以及一個用來提交數據的button(按鈕)。這個提交按鈕的PostBackUrl屬性被指定為另外一個網頁,這樣使得表單提交的時候,數據可以發送到那個頁面。注意:這個例子中,表單元素通過設置 method(方法)屬性,讓表單提交時采用post[2]提交方式,但這不是必要的,因為所有cross postback(跨頁投遞)根據設計均使用post方法。

使用先前頁面

ASP.NET頁面經由跨頁投遞的調用而載入的時候,它上面的對象的IsPostBack屬性不會被觸發。不過,有一項叫做PreviousPage(前一頁)的屬性使你能夠訪問和使用那些應用跨頁投遞的頁面。

每當一個跨頁請求發生時,當前頁的PreviousPage屬性就把促發投遞的頁面引用保存下來。如果頁面的產生不是來自跨頁投遞的激發,或者說頁面處于不同的程序組,那么PreviousPage屬性將不會被初始化。

你可以通過檢查PreviousPage對象來確定頁面的載入是否為跨頁投遞的結果。值如果為null,則說明是普通的載入,而非null值則表明網頁來自跨頁投遞。此外,頁面類(Page class)還包含了一個稱作IsCrossPagePostBack的方法(method),專門用來確定頁面是不是跨頁投遞的結果。

一旦確定發生了跨頁投遞,你就可以通過PreviousPage對象的FindControl方法去訪問調用頁(calling page)上的控件。下面的代碼是我們例子中的第二頁;它由前面列出的頁面所調用。

以下是引用片段:

  1. 〈%@ Page language="vb" %〉  
  2. 〈!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML   
  3. 4.0 Transitional//EN" 〉  
  4. 〈html〉〈head〉  
  5. 〈title〉Cross Postback Example 2〈/title〉  
  6. 〈/head〉〈body〉  
  7. 〈script language="vb" runat="server"〉  
  8. Sub Page_Load()  
  9. If Not (Page.PreviousPage Is Nothing) Then 
  10. If Not (Page.IsCrossPagePostBack) ThenResponse.Write  
  11. ("Name:" + CType(PreviousPage.FindControl("txtName"),   
  12. TextBox).Text + "〈BR〉")Response.Write("E-mail:" +   
  13. CType(PreviousPage.FindControl("txtE-mailAddress"),   
  14. TextBox).Text + "〈BR〉")   
  15. End If  
  16. End If  
  17. End Sub  
  18. 〈/script〉  
  19. 〈/body〉  
  20. 〈/html〉  

這個頁先判斷它是不是由跨頁投遞所調用。如果是,就通過FindControl方法訪問來自調用頁的數值,并把用此方法得到的控件轉換為TextBox控件,然后顯示它們的Text(文本)屬性的內容。

你可以把整個PreviousPage對象轉換成觸發跨頁投遞的頁面類型。這個方法允許你訪問頁面的全局屬性(public properties)和方法。下面代碼是添加了兩個屬性的***個清單,這兩個屬性用于訪問域值。

#p#

以下是引用片段:

  1. 〈%@ Page language="vb" % 〉  
  2. 〈!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML   
  3. 4.0 Transitional//EN"  〉  
  4. 〈html 〉〈head 〉  
  5. 〈title 〉Cross Postback Example〈/title 〉  
  6. 〈script language="vb" runat="server" 〉  
  7. Public ReadOnly Property Name 
  8. Get  
  9. Return Me.txtName.Text  
  10. End Get  
  11. End Property  
  12. Public ReadOnly Property E-mailAddress  
  13. Get  
  14. Return Me.txtE-mailAddress.Text  
  15. End Get  
  16. End Property  
  17. 〈/script 〉〈/head 〉〈body 〉  
  18. 〈form id="frmCrossPostback1" method="post"   
  19. runat="server" 〉  
  20. 〈asp:Label ID="lblName" runat="server"   
  21. Text="Name:" 〉〈/asp:Label 〉   
  22. 〈asp:TextBox ID="txtName" runat="server" 〉  
  23. 〈/asp:TextBox 〉〈br / 〉  
  24. 〈asp:Label ID="lblE-mailAddress" runat="server"   
  25. Text="E-mail:" 〉〈/asp:Label 〉  
  26. 〈asp:TextBox ID="txtE-mailAddress" runat="server" 〉  
  27. 〈/asp:TextBox 〉〈br / 〉  
  28. 〈asp:Button ID="btnSubmit" runat="server"   
  29. Text="Submit" PostBackUrl="CrossPostback2.aspx" / 〉  
  30. 〈/form 〉  
  31. 〈/body 〉  
  32. 〈/html 〉  

既然現在屬性已經建好,那你就能很容易訪問它們。要警惕的是,Page類的PreviousPage對象必須轉換成正確的類型,這樣才能正確訪問它的屬性。這可以通過把它轉換成合適的page類別的對象加以實現。

以下是引用片段:

  1. 〈%@ Page language="vb"% 〉  
  2. 〈%@ Reference Page="~/CrossPostback1.aspx" % 〉  
  3. 〈!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML   
  4. 4.0 Transitional//EN"  〉  
  5. 〈html 〉  
  6. 〈head 〉  
  7. 〈title 〉Cross Postback Example 3〈/title 〉  
  8. 〈/head 〉〈body 〉  
  9. 〈script language="vb" runat="server" 〉  
  10. Sub Page_Load()  
  11. Dim cppPage As CrossPostback1_aspx  
  12. If Not (Page.PreviousPage Is Nothing) Then 
  13. If Not (Page.IsCrossPagePostBack) Then 
  14. If (Page.PreviousPage.IsValid)   
  15. ThencppPage = CType(PreviousPage, CrossPostBack1_aspx)  
  16. Response.Write("Name:" + cppPage.Name + "〈br 〉")  
  17. Response.Write("E-mail:" + cppPage.E-mailAddress)   
  18. End If  
  19. End If  
  20. End If  
  21. End Sub  
  22. 〈/script 〉  
  23. 〈/body 〉  
  24. 〈/html 〉  

說明了這一點,它在頁面頭部定義了調用頁的一項引用,那樣這個引用類型就能在代碼中使用。通過這項引用,實際的VB.NET代碼使用CType函數把PreviousPage對象轉換成了適當的類型。這之后,那些屬性就可以像代碼示范的那樣使用了。

關于上述清單中PreviousPage對象IsValid方法的使用在此提醒一下:前頁的IsValid屬性保證你對它操作之前,它已通過所有合法驗證測試。

總結

在網頁間傳遞數據參數有很多項應用,包括保持個人用戶信息。祖傳的網頁解決方案,像使用querystring和cookies,允許你很容易當提交發生時從一個頁面指向另一個頁面。

ASP.NET 1.1除了提供額外方法外,對這些方法也能很好地支持,可是,ASP.NET跨頁提交功能,使這方面又有了長足發展。它讓一個網頁處理來自另一網頁的數據變得簡單。在你開發你的下一個ASP.NET 2.0程序的時候,可要好好利用這個新概念的優勢啊。

【編輯推薦】

  1. ASP.NET環境下的Shell函數
  2. 在ASP.NET中向數據庫批量插入數據
  3. ASP.NET用Post方式向網頁發送數據
  4. ASP.NET 2.0部署WEB應用程序淺析
  5. ASP.NET上傳文件面面觀
責任編輯:冰荷 來源: it55
相關推薦

2009-07-27 17:26:39

ASP.NET功能

2009-07-29 16:08:07

ASP和ASP.NET

2009-07-22 16:25:41

ASP.NET AJA

2009-07-24 10:14:22

ASP.NET開發

2009-07-28 16:57:50

ASP.NET Ses

2009-08-05 11:14:33

ASP.NET ISA

2009-07-23 13:19:51

2009-08-21 10:51:55

ASP.NET Rou解析URL

2009-09-09 12:35:00

ASP.NET回車提交回車提交事件

2009-07-29 15:34:13

2015-11-19 09:26:01

ASP.NET跨平臺實踐

2017-03-06 11:13:57

ASP.NETCoreMVC

2009-10-26 15:55:43

URL Routing

2009-07-23 13:09:23

2009-08-19 13:44:00

ASP.NET Lis

2009-07-28 13:39:44

加載ViewStateASP.NET

2009-08-04 10:43:59

ASP.NET控件開發

2009-08-04 18:10:35

ASP.NET動態編譯

2009-07-27 13:39:06

Web窗體頁ASP.NET

2010-10-08 14:32:32

ASP.NET MVCNuPack
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品一区二区在线 | 台湾a级理论片在线观看 | 91偷拍精品一区二区三区 | 欧美一区二区 | 粉嫩av在线 | h在线播放 | 国产精品网址 | 91久久精品一区二区二区 | 中文字幕一区二区三区日韩精品 | 美女视频一区二区三区 | 一区二区三区四区在线 | 国产久视频 | 色婷婷久久久久swag精品 | aaa国产大片 | 美女在线国产 | 中文字幕在线不卡 | 99久久精品国产毛片 | 久久99精品久久久久久国产越南 | 青青久草 | 二区在线视频 | 国产成人精品一区二区三区视频 | 久久久91精品国产一区二区精品 | 秋霞a级毛片在线看 | 日本免费视频在线观看 | 日韩at| 亚洲精品一区二区三区四区高清 | 国产精品嫩草影院精东 | 国产精品久久久久久久久久久久久 | 成年人在线 | 日本福利视频 | 国产精品久久久久久久久免费软件 | 日本精a在线观看 | 日韩在线观看中文字幕 | 精品久久久久久亚洲综合网 | 国产免费观看一区 | 国产农村妇女毛片精品久久麻豆 | 亚洲福利视频一区二区 | 成年人视频免费在线观看 | 影音先锋欧美资源 | 免费在线成人 | 久久久久久久久久久91 |