在已經(jīng)發(fā)布的 ASP.NET2.0 中,無(wú)刷新頁(yè)面開(kāi)發(fā)相關(guān)部分同 beta2 有不少改動(dòng)。而且在越來(lái)越多的 Ajax 開(kāi)發(fā)包被開(kāi)發(fā)出來(lái)的情況下, ASP.NET2.0 自帶的無(wú)刷新頁(yè)面技術(shù)沒(méi)有被很多人了解,甚至不少人認(rèn)為該功能有些“雞肋”。但如果我們僅僅是在程序中加入很少部分的 Ajax 特性, Atlas 、 Ajax.Net 等就顯得有些“殺雞用牛刀”的感覺(jué)了。而且,我認(rèn)為使用 ASP.NET2.0 提供的方法進(jìn)行開(kāi)發(fā)并不很復(fù)雜,相反,使用很少的代碼就可以做出來(lái)很棒的效果!
下面我來(lái)一步一步的帶大家開(kāi)發(fā)無(wú)刷新的頁(yè)面!
第一步:實(shí)現(xiàn) ICallbackEventHandler 接口
ICallbackEventHandler接口位于System.Web.UI命名空間下。在beta2時(shí),ICallbackEventHandler只包含一個(gè)RaiseCallbackEvent方法,即處理回調(diào)事件,又返回處理結(jié)果。在正式版中,它變成了包含GetCallbackResult和RaiseCallbackEvent兩個(gè)成員方法,第一個(gè)用來(lái)返回回調(diào)事件的結(jié)果,第二個(gè)用來(lái)出來(lái)回調(diào)事件。這個(gè)變化主要是為了編寫(xiě)Web控件而做的改動(dòng),具體可以看一下GridView等控件中的實(shí)現(xiàn)代碼。
建立一個(gè) Web 網(wǎng)站,我們來(lái)修改 default.aspx.cs 文件:
2 public void RaiseCallbackEvent(string eventArgument)
3 {
4 //可以根據(jù)傳遞的參數(shù)不同,調(diào)用不同的處理邏輯
5 str = "從服務(wù)器端返回的內(nèi)容:" + eventArgument;
6 }
7
8 public string GetCallbackResult()
9 {
10 return str;
11 }
12
第二步:注冊(cè)回調(diào)方法
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
2 //由button調(diào)用
3 function CallServer(inputcontrol, context)
4 {
5 context.innerHTML = "Loading

6 arg = inputcontrol.value;
7 //注冊(cè)回調(diào)方法
8 <%= ClientScript.GetCallbackEventReference(this, "arg", "ReceiveServerData", "context")%>;
9 }
10 //在回調(diào)方法中注冊(cè)的接收返回結(jié)果的函數(shù)
11 function ReceiveServerData(result, context)
12 {
13 context.innerHTML = result;
14 }
15 </script>
16
好了,一個(gè)無(wú)刷新的頁(yè)面就開(kāi)發(fā)完了,它可以將你在 TextBox 中輸入的文字,通過(guò)服務(wù)器代碼寫(xiě)回到頁(yè)面的 Label 中。是不是很簡(jiǎn)單?你可以運(yùn)行一下你的程序看看效果啦!
下面我們來(lái)分析一下這些代碼。
首先,我們看
ClientScript是System.Web.UI.Page對(duì)象的一個(gè)屬性,它是System.Web.UI.ClientScriptManager對(duì)象。用于管理客戶端腳本,GetCallbackEventReference方法用于注冊(cè)一個(gè)服務(wù)器端事件的客戶端回調(diào)。它的第四個(gè)參數(shù)“Context”非常重要,但在MSDN中并沒(méi)有相關(guān)的例子和詳細(xì)的說(shuō)明。在我上面給的代碼中可以看到,調(diào)用CallServer方法時(shí),傳遞的Context參數(shù)就是Label1,而ReceiveServerData的第二個(gè)參數(shù)“Context”就是被傳遞過(guò)來(lái)的Label1。在我的例子中,Context被我用于設(shè)定一個(gè)用來(lái)顯示服務(wù)端返回結(jié)果的控件。其實(shí),你可以將任意的對(duì)象賦值給Context,它都會(huì)被傳遞給本地端處理回調(diào)返回結(jié)果的函數(shù),這樣,你就可以根據(jù)調(diào)用前指定的“上下文”靈活的操作返回結(jié)果了!在我給出的完整例子中,你可以看到一個(gè)使用Context做的無(wú)刷新顯示GridView的例子。
在這里我要說(shuō)個(gè)題外話,Context這么重要的參數(shù)在MSDN中不但沒(méi)有詳細(xì)的說(shuō)明,而且VS2005中文正式版MSDN中關(guān)于回調(diào)的例子竟然還是beta2時(shí)的實(shí)現(xiàn)!這個(gè)版本的MSDN可以說(shuō)是我用過(guò)的版本中品質(zhì)最差的。不過(guò)現(xiàn)在的MSND可以用“相當(dāng)”龐大來(lái)形容,出錯(cuò)也是在所難免的,希望下個(gè)版本的MSND會(huì)好一些。
OK,在ASP.NET 2.0中開(kāi)發(fā)具有Ajax特性的東東不難吧!其實(shí)就是兩步:
1、 在Server端實(shí)現(xiàn)ICallbackEventHandler接口,在接口包含的方法中根據(jù)傳遞的參數(shù)分別調(diào)用不同的處理方法,然后返回結(jié)果;
2、 在Client端注冊(cè)回調(diào)函數(shù)(當(dāng)然你也可以在Server端注冊(cè)),然后實(shí)現(xiàn)處理回調(diào)結(jié)果的函數(shù)。其中,如果對(duì)Context能干靈活運(yùn)行,你就可以做出非常好的效果了。
在我給出的完整例子中,你們可以看到更完整的處理邏輯和更漂亮的特效,當(dāng)然,增加的代碼還是很少的!
有將近一年沒(méi)有寫(xiě)Blog了,手也比較生了。以前cnblogs的文章我是基本上天天都看的,現(xiàn)在一兩個(gè)星期看一次就不錯(cuò)了,還是走馬觀花的瀏覽幾篇而已。如今每天都是為了生活而奔波,人在江湖,身不由己呀!
發(fā)了半天牢騷,我也預(yù)告一下,我會(huì)在最近寫(xiě)一些介紹Atlas的文章。其實(shí)Atlas也有很多人都寫(xiě)過(guò)了,不過(guò)大都是根據(jù)官方文檔的模式寫(xiě)的,而最近發(fā)布的幾版CTP變化挺大的(實(shí)現(xiàn)的功能也比較誘人!),對(duì)新特性介紹的文章比較少,所以我就來(lái)獻(xiàn)丑了,希望對(duì)大家使用Atlas有所幫助。