ASP.NET 2.0 正式版中無刷新頁面的開發(fā)

2010-08-28 10:51:09來源:西部e網(wǎng)作者:

   在已經(jīng)發(fā)布的 ASP.NET2.0 中,無刷新頁面開發(fā)相關部分同 beta2 有不少改動。而且在越來越多的 Ajax 開發(fā)包被開發(fā)出來的情況下, ASP.NET2.0 自帶的無刷新頁面技術沒有被很多人了解,甚至不少人認為該功能有些“雞肋”。但如果我們僅僅是在程序中加入很少部分的 Ajax 特性, Atlas Ajax.Net 等就顯得有些“殺雞用牛刀”的感覺了。而且,我認為使用 ASP.NET2.0 提供的方法進行開發(fā)并不很復雜,相反,使用很少的代碼就可以做出來很棒的效果!

   下面我來一步一步的帶大家開發(fā)無刷新的頁面!

 

 第一步:實現(xiàn) ICallbackEventHandler 接口

 

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

建立一個 Web 網(wǎng)站,我們來修改 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         //可以根據(jù)傳遞的參數(shù)不同,調(diào)用不同的處理邏輯
 5         str = "從服務器端返回的內(nèi)容:" + eventArgument;
 6     }
 7 
 8     public string GetCallbackResult()
 9     {
10         return str;
11     }
12 

 

  第二步:注冊回調(diào)方法

   我們在 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>
4 

 

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


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

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

   首先,我們看

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

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

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

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

1、              Server端實現(xiàn)ICallbackEventHandler接口,在接口包含的方法中根據(jù)傳遞的參數(shù)分別調(diào)用不同的處理方法,然后返回結果;

2、              Client端注冊回調(diào)函數(shù)(當然你也可以在Server端注冊),然后實現(xiàn)處理回調(diào)結果的函數(shù)。其中,如果對Context能干靈活運行,你就可以做出非常好的效果了。

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

 

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

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

 

示例代碼下載4K

關鍵詞:ASP.NET

贊助商鏈接: