一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

AjaxPro 內部機制探討

  應當承認我這人實在算不上弄潮兒,Ajax 早已流行得一塌糊涂,我卻始終沒有來研究一下這個東東。上次做網站的時候,BOSS 就跟我講過,可以參考一下 Ajax 的技術,我嘴上答應,心里卻不是十分的在乎。究其原因,一來是我這人比較固步自封,二來起初確實也沒太相信 Ajax 真有 BOSS 說的那么神奇。

  轉變是從昨天天始的,這一周在公司主要精力都是在用 C++ 寫 framework,不得不承認它比較辛苦,細枝末節之處非常之煩,昨天下午呆著呆著就不想干活了,就開始四處游蕩,正好看到我們自己也有項目已經成功應用了 Ajax,于是也就想看一看,無奈那幫家伙的開發文檔是出奇的少,只好在網上找找資料,自己研究研究吧。

  作為一個技術人員,我看到一項新技術,總是喜歡琢磨琢磨它內部是如何實現的。在對 Ajax 有了初步認識以后,自然想看看其內部機制,但是令我失望的是,至少介紹 Ajax 內部實現的文章少之又少,好容易找到一篇,卻也只是簡單列了列一些 Javascript 代碼,并且沒什么解釋,頗為郁悶。想想求人不如求己,況且自己研究的或許印象更深一些。于是找到了一個 AjaxPro,下來琢磨琢磨,只是對于 JavaScript 我實在知之甚少,不明白之處依然很多,不過還是想寫出來,拋磚引玉,望高人們不吝指教。

  一、使用的例子

  本文使用的例子很簡單,一個文本框,在其中敲入文字之后,下方就顯示該文字并加上一個“(Hello from server)”。源碼如下(有刪節):

 1<%@ Page language="c#" ClassName="KeyPressDemo" Inherits="System.Web.UI.Page" %>
 2<script runat="server" language="c#">
 3
 4private void Page_Load(object sender, EventArgs e)
 5{
 6    AjaxPro.Utility.RegisterTypeForAjax(typeof(KeyPressDemo));
 7}

 8
 9[AjaxPro.AjaxMethod]
10public string EchoInput(string s)
11{
12    return s += " (Hello from server)";
13}

14
15
script>
16
17<form id="Form1" method="post" runat="server">form>
18
19<div class="content">
20<h1>KeyPressDemo Examplesh1>
21<p>Press any key in the textbox and see the echo in the DIV element on the right side.p>
22<input type="text" id="myinput" onkeyup="doTest1();"/> <div id="mydisplay">---- empty ----div>
23<p><i>Note, that I do not update the display if a request is running currently.i>p>
24div>
25
26<script type="text/Javascript" defer="defer">
27
28var timer = null;
29
30function doTest1() {
31    if(timer != null{
32      clearTimeout(timer);
33    }

34    timer = setTimeout(doTest1_next, 100);
35}

36
37function doTest1_next() {
38    var ele = document.getElementById("myinput");
39    ASP.KeyPressDemo.EchoInput(ele.value, doTest1_callback);
40}

41
42function doTest1_callback(res) {
43    var ele = document.getElementById("mydisplay");
44    ele.innerHTML = res.value;
45}

46
47
script>
  二、Ajax ClientScript 的執行總體流程

  好,有了源頁面代碼,又有了兩個 ClientScript 文件,我們就可以分析客戶端的執行流程了。以下是我畫的一張簡單的流程圖:



  我們一個一個地來分析。

  三、HTML頁面做了什么?

  第一步,當我們在 TextBox 里輸入字符后,將會觸發 onkeyup 事件。它要執行 doTest1 方法。見頁面代碼里的第22行。

  第二步,doTest1 方法使用 setTimeout 函數,設定了 100 毫秒后,執行 doTest1_next 方法。見頁面代碼里的第34行。

  第三步,doTest1_next 方法調用了 ASP.KeyPressDemo.EchoInput 方法,它帶有兩個參數,第一個是我們在文本框中輸入的值,當然是個字符串類型的了;第二個則是一個 callback 函數,請留心這個函數,它將于整個流程的最后執行。

  好,我們知道頁面的客戶端無外乎就是 HTML 和 JavaScript,雖然 ASP.KeyPressDemo.EchoInput 方法酷似頁面里我們自己用 C# 寫的函數,但可以肯定的是它絕對是用 JavaScript 實現的。在哪兒呢?嗯,在我們從 Temporary InterNET Files 目錄下找到的 ASP.KeyPressDemo,App_Web_vxhzzzxr.ashx 里。

  四、ASP.KeyPressDemo,App_Web_vxhzzzxr.ashx 的實現

  這個文件很小,以下是它的全部源碼:

 1addNamespace("ASP");
 2ASP.KeyPressDemo_class = Class.create();
 3ASP.KeyPressDemo_class.prototype = (new AjaxPro.Request()).extend({
 4    EchoInput: function(s, callback) {
 5        return this.invoke("EchoInput"{"s":s}, callback);
 6    }
,
 7    initialize: function() {
 8        this.url = "/ajaxdemo/ajaxpro/ASP.KeyPressDemo,App_Web_vxhzzzxr.ashx";
 9    }

10}
)
11ASP.KeyPressDemo = new ASP.KeyPressDemo_class();
12  五、Invoke 函數

  Invoke 函數是核心所在,前面我畫的流程圖中已經簡單地描述了它的主要流程。不過這個函數太重要了,這里還是列出它的全部源碼:

 1AjaxPro.Request = Class.create();
 2AjaxPro.Request.prototype = (new AjaxPro.Base()).extend({
 3    invoke: function(method, data, callback) {
 4        var async = typeof callback == "function" && callback != AjaxPro.noOperation;
 5        var json = AjaxPro.toJSON(data) + "/r/n";
 6
 7        if(AjaxPro.cryptProvider != null)
 8            json = AjaxPro.cryptProvider.encrypt(json);
 9
10        this.callback = callback;
11
12        if(async) {
13            this.xmlHttp.onreadystatechange = this.doStateChange.bind(this);
14            if(typeof this.onLoading == "function"this.onLoading(true);
15        }

16            
17        this.xmlHttp.open("POST"this.url, async);
18        this.xmlHttp.setRequestHeader("Content-Type""application/x-www-form-urlencoded");
19        this.xmlHttp.setRequestHeader("Content-Length", json.length);
20        this.xmlHttp.setRequestHeader("Ajax-method", method);
21        
22        if(AjaxPro.token != null && AjaxPro.token.length > 0)
23            this.xmlHttp.setRequestHeader("Ajax-token", AjaxPro.token);
24
25        if(MS.Browser.isIE)
26            this.xmlHttp.setRequestHeader("Accept-Encoding""gzip, deflate");
27        else
28            this.xmlHttp.setRequestHeader("Connection""close");    // Mozilla Bug #246651
29
30        if(this.onTimeout != null && typeof this.onTimeout == "function")
31            this.timeoutTimer = setTimeout(this.timeout.bind(this), this.timeoutPeriod);
32
33        this.xmlHttp.send(json);
34        
35        json = null;
36        data = null;
37        delete json;
38        delete data;
39        
40        if(!async) {
41            return this.createResponse();
42        }

43        
44        return true;    
45    }

46}
);
47  七、this.xmlHttp 從何而來?

  前面我們看到了 this.xmlHttp 大顯神威。那么它是哪兒來的?看看 AjaxPro.Request 類的 initialize 函數吧(有刪節):

1initialize: function(url) {
2    this.xmlHttp = new XMLHttpRequest();
3}

4

NET技術AjaxPro 內部機制探討,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: a爱视频 | 四虎国产永久在线精品免费观看 | 国产三级精品美女三级 | 日本一区二区视频在线观看 | 91精品久久久久亚洲国产 | 女人夜色黄网在线观看 | 国产高清自拍一区 | 四虎看黄| 黄在线视频播放免费网站 | 91麻豆精品国产91久久久久 | www视频在线播放 | 色婷婷在线播放 | 韩国一级片免费 | 国产一级不卡毛片 | 色视频免费观看 | 婷婷丁香五月中文字幕 | 91精品国产麻豆国产自产在线 | 色婷婷激情五月综合 | 中文字幕在线永久在线视频2020 | 91蝌蚪视频在线观看 | 日韩免费视频一区 | 久久私人影院 | 网色视频| 色多多视频官网 | 免费激情网站 | 美女的毛片 | 激情小说亚洲 | 久久青青草原热精品 | 色综合888 | 九九99九九在线精品视频 | 亚洲一区小说区中文字幕 | 免费在线观看黄视频 | 99久久国产综合精麻豆 | 日本青草视频 | 中文字幕二区三区 | 亚洲第一区在线观看 | 国产精品视频区 | 国产区在线观看视频 | 免费看黄网站在线看 | 欧美成a人免费观看久久 | 91精品国产高清久久久久久 |