AJAX技術所提倡的無刷新回調,在原來的技術中需要寫大量的JavaScript代碼或使用一些AJAX框架,使得開發效率和可維護性大大降低。其實ASP.NET2.0中,已經提供了這樣的接口,這就是ICallbackEventHandler。
關于ICallbackEventHandler網上已經有很多文章介紹了,這篇實為畫蛇添足。
ICallbackEventHandler存在于System.Web.UI中,我們先做一個非常簡單的例子來試用一下。
第一步,在VS2005中建立一個新的WEB窗件。
第二步,在ASPX中,放上一段HTML代碼(如下):

2

3

4

5

6

7

第三步,然后在<HEAD></HEAD>中放入一段JavaScript腳本:

2

3

4

5

6

7

8

9

10

11

12

第四步,在此ASPX的后臺CS代碼中,繼承ICallbackEventHandler接口,并實現接口中的兩個方法:
ICallbackEventHandler.GetCallbackResult()
和
ICallbackEventHandler.RaiseCallbackEvent(string eventArgument)
第五步,增加一個變量CallBackValue,并修改接口的兩個方法為:

2

3

4

5

6

7

8

9

10

11

12

第六步,運行,界面上會出現一個按鈕,點擊后,會將“測試”這個字符串傳至后臺,后臺C#代碼將字符串加上“,OK”后返回給客戶端的JavaScript代碼,并顯示。
以上六步,就可以實現無刷新回調了。現在,我們來分析一下幾段代碼。
先看第三步中的JavaScript代碼,其中的CallServer()方法中進行了回調,回調的語句為:
<%= ClientScript.GetCallbackEventReference(this, "product", "ReceiveServerData",null)%>;
里面四個參數中第二個參數指定將product這個JavaScript中的字符串變量傳回后臺,第三個參數指定了從后臺返回時接收返回信息的JavaScript方法ReceiveServerData(string Value)。
第五步中后臺的兩個方法,一個ICallbackEventHandler.RaiseCallbackEvent(string eventArgument)用來接收前臺JavaScript中傳來的字符串變量,并賦值給內部變量this.CallBackValue,另一個方法ICallbackEventHandler.GetCallbackResult()將變更后的內部變量this.CallBackValue返回給前臺JavaScript方法ReceiveServerData(string Value)。
調用的順序是: (前臺)CallServer() --> (后臺)ICallbackEventHandler.RaiseCallbackEvent(string eventArgument) --> (后臺)ICallbackEventHandler.GetCallbackResult() --> (前臺)ReceiveServerData(string Value)。
整個調用過程非常簡單,而其中非常關鍵的一步是第三步的
<%= ClientScript.GetCallbackEventReference(this, "product", "ReceiveServerData",null)%>;
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
