生活随笔
收集整理的這篇文章主要介紹了
在.NET 2.0正式版中开发无刷新页面
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
在已經發(fā)布的 ASP.NET2.0 中,無刷新頁面開發(fā)相關部分同 beta2 有不少改動。而且在越來越多的 Ajax 開發(fā)包被開發(fā)出來的情況下, ASP.NET2.0 自帶的無刷新頁面技術沒有被很多人了解,甚至不少人認為該功能有些“雞肋”。但如果我們僅僅是在程序中加入很少部分的 Ajax 特性, Atlas 、 Ajax.Net 等就顯得有些“殺雞用牛刀”的感覺了。而且,我認為使用 ASP.NET2.0 提供的方法進行開發(fā)并不很復雜,相反,使用很少的代碼就可以做出來很棒的效果!
下面我來一步一步的帶大家開發(fā)無刷新的頁面!
第一步:實現 ICallbackEventHandler 接口
ICallbackEventHandler接口位于System.Web.UI命名空間下。在beta2時,ICallbackEventHandler只包含一個RaiseCallbackEvent方法,即處理回調事件,又返回處理結果。在正式版中,它變成了包含GetCallbackResult和RaiseCallbackEvent兩個成員方法,第一個用來返回回調事件的結果,第二個用來出來回調事件。這個變化主要是為了編寫Web控件而做的改動,具體可以看一下GridView等控件中的實現代碼。
建立一個 Web 網站,我們來修改 default.aspx.cs 文件:
c# 代碼
public?partial?class?_Default?:?System.Web.UI.Page,?ICallbackEventHandler ?? { ?? ????private?string?str; ?? ????public?void?RaiseCallbackEvent(string?eventArgument) ?? ????{ ?? ????????//可以根據傳遞的參數不同,調用不同的處理邏輯? ?? ????????str?=?"從服務器端返回的內容:"?+?eventArgument; ?? ????} ?? ?? ????public?string?GetCallbackResult() ?? ????{ ?? ????????return?str?+?"——【GetCallbackResult】"; ?? ????}? ?? ?? ????protected?void?Page_Load(object?sender,?EventArgs?e) ?? ????{ ?? ?? ????} ?? }?? 第二步:注冊回調方法
我們在 default.aspx 頁面中添加一個 TextBox ,一個 Label 和一個 Html 控件 Button ,并給 Button 添加 onclick 事件:
HTML?代碼
<asp:TextBox?ID="TextBox1"?runat="server"></asp:TextBox> ?? <asp:Label?ID="Label1"?runat="server"?Text="Label"></asp:Label><br?/> ?? ?? <input?id="Button1"?type="button"?value="提交到Label1"?οnclick="CallServer(TextBox1,?Label1)"/><br/>?? ?? HTML?代碼
<script?type="text/javascript">??? ?? ??????//由button調用?? ?? ??????function?CallServer(inputcontrol,?context)?? ?? ??????{??? ?? ???????????context.innerHTML?=?"Loading";?? ?? ???????????arg?=?inputcontrol.value;?? ?? ???????????//注冊回調方法?? ?? ???????????<%=?ClientScript.GetCallbackEventReference(this,?"arg",?"ReceiveServerData",?"context")%>;??? ?? ????????}?? ?? ??????//在回調方法中注冊的接收返回結果的函數?? ?? ???????function?ReceiveServerData(result,?context)??? ?? ???????{?? ?? ???????????context.innerHTML?=?result;?? ?? ???????}?? ?? ???</script>???? 好了,一個無刷新的頁面就開發(fā)完了,它可以將你在 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中開發(fā)具有Ajax特性的東東不難吧!其實就是兩步:
1、 在Server端實現ICallbackEventHandler接口,在接口包含的方法中根據傳遞的參數分別調用不同的處理方法,然后返回結果;
2、 在Client端注冊回調函數(當然你也可以在Server端注冊),然后實現處理回調結果的函數。其中,如果對Context能干靈活運行,你就可以做出非常好的效果了。
轉載于:https://www.cnblogs.com/gllgsoft/archive/2008/08/06/1262167.html
總結
以上是生活随笔為你收集整理的在.NET 2.0正式版中开发无刷新页面的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。