Asp.NET 2.0中無重新整理頁面的開發

來源:互聯網
上載者:User
在已經發布的 ASP.NET2.0 中,無重新整理頁面開發相關部分同 beta2 有不少改動。而且在越來越多的 Ajax 開發包被開發出來的情況下, ASP.NET2.0 內建的無重新整理頁面技術沒有被很多人瞭解,甚至不少人認為該功能有些“雞肋”。但如果我們僅僅是在程式中加入很少部分的 Ajax 特性, Atlas 、 Ajax.Net 等就顯得有些“殺雞用牛刀”的感覺了。而且,我認為使用 ASP.NET2.0 提供的方法進行開發並不很複雜,相反,使用很少的代碼就可以做出來很棒的效果!

  下面我來一步一步的帶大家開發無重新整理的頁面!

  第一步:實現 ICallbackEventHandler 介面

  ICallbackEventHandler介面位於System.Web.UI命名空間下。在beta2時,ICallbackEventHandler只包含一個RaiseCallbackEvent方法,即處理回調事件,又返回處理結果。在正式版中,它變成了包含GetCallbackResult和RaiseCallbackEvent兩個成員方法,第一個用來返回回調事件的結果,第二個用來出來回調事件。這個變化主要是為了編寫Web控制項而做的改動,具體可以看一下GridView等控制項中的實現代碼。

  建立一個 Web 網站,我們來修改 default.aspx.cs 檔案:

  1 public partial class _Default : System.Web.UI.Page, ICallbackEventHandler
  1 private string str;
  2 public void RaiseCallbackEvent(string eventArgument)
  3 {
  4 //可以根據傳遞的參數不同,調用不同的處理邏輯
  5 str = "從伺服器端返回的內容:" + eventArgument;
  6 }
  7
  8 public string GetCallbackResult()
  9 {
  10 return str;
  11 }
  12

  第二步:註冊回調方法

  我們在 default.aspx 頁面中添加一個 TextBox ,一個 Label 和一個 Html 控制項 Button ,並給 Button 添加 onclick 事件:

1 <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox> 
2 <input id="Button1" type="button" value="提交到Label1" onclick="CallServer(TextBox1, Label1)"/><br/> 
3 <asp:Label ID="Label1" runat="server" Text="Label1:"></asp:Label> 

 1     <script type="text/javascript">  
 2        //由button調用 
 3        function CallServer(inputcontrol, context) 
 4        {  
 5             context.innerHTML = "Loading"; 
 6             arg = inputcontrol.value; 
 7             //註冊回調方法 
 8             <%= ClientScript.GetCallbackEventReference(this, "arg", "ReceiveServerData", "context")%>;  
 9         } 
10         //在回調方法中註冊的接收返回結果的函數 
11         function ReceiveServerData(result, context)  
12         { 
13             context.innerHTML = result; 
14         } 
15     </script> 
16 

  好了,一個無重新整理的頁面就開發完了,它可以將你在 TextBox 中輸入的文字,通過伺服器代碼寫回到頁面的 Label 中。是不是很簡單?你可以運行一下你的程式看看效果啦!

  下面我們來分析一下這些代碼。

  首先,我們看

<%= ClientScript.GetCallbackEventReference(this, "arg", "ReceiveServerData", "context")%>;

  ClientScript是System.Web.UI.Page對象的一個屬性,它是System.Web.UI.ClientScriptManager對象。用於管理用戶端指令碼,GetCallbackEventReference方法用於註冊一個伺服器端事件的用戶端回調。它的第四個參數“Context”非常重要,但在MSDN中並沒有相關的例子和詳細的說明。在我上面給的代碼中可以看到,調用CallServer方法時,傳遞的Context參數就是Label1,而ReceiveServerData的第二個參數“Context”就是被傳遞過來的Label1。在我的例子中,Context被我用於設定一個用來顯示服務端返回結果的控制項。其實,你可以將任意的對象賦值給Context,它都會被傳遞給本地端處理回調返回結果的函數,這樣,你就可以根據調用前指定的“上下文”靈活的操作返回結果了!在我給出的完整例子中,你可以看到一個使用Context做的無重新整理顯示GridView的例子。

  在這裡我要說個題外話,Context這麼重要的參數在MSDN中不但沒有詳細的說明,而且VS2005中文正式版MSDN中關於回調的例子竟然還是beta2時的實現!這個版本的MSDN可以說是我用過的版本中品質最差的。不過現在的MSND可以用“相當”龐大來形容,出錯也是在所難免的,希望下個版本的MSND會好一些。

  OK,在ASP.NET 2.0中開發具有Ajax特性的東東不難吧!其實就是兩步:

  1、 在Server端實現ICallbackEventHandler介面,在介面包含的方法中根據傳遞的參數分別調用不同的處理方法,然後返回結果;

  2、 在Client端註冊回呼函數(當然你也可以在Server端註冊),然後實現處理回調結果的函數。其中,如果對Context能幹靈活運行,你就可以做出非常好的效果了。

  在我給出的完整例子中,你們可以看到更完整的處理邏輯和更漂亮的特效,當然,增加的代碼還是很少的!

  有將近一年沒有寫Blog了,手也比較生了。以前cnblogs的文章我是基本上天天都看的,現在一兩個星期看一次就不錯了,還是走馬觀花的瀏覽幾篇而已。如今每天都是為了生活而奔波,人在江湖,身不由己呀!

  發了半天牢騷,我也預告一下,我會在最近寫一些介紹Atlas的文章。其實Atlas也有很多人都寫過了,不過大都是根據官方文檔的模式寫的,而最近發布的幾版CTP變化挺大的(實現的功能也比較誘人!),對新特性介紹的文章比較少,所以我就來獻醜了,希望對大家使用Atlas有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.