分享個自己的ajax封裝

來源:互聯網
上載者:User

      工作了也兩年了,因為認真研讀過  professional javascript for web developers 一書的翻譯版,一直自以為自己js水平可以,因此工作中對於很多的js架構很不感冒,儘管也研究過這些架構,也認為確實很強大。自己工作中的遇到的就弄個自己的簡單的實現,這個ajax的封裝也主要代碼是來自 professional javascript for web developers ,只是做了一些處理,對於應付自己工作的需求已是足夠了。

 

       首先,先展示一下怎樣調用

//定義回呼函數 function handleresponse(XMLHTTP) {  if (XMLHTTP.readyState == 4) {     var response = XMLHTTP.responseText;        //  這裡寫自己的處理常式     }   } }  function checktext(obj)  {      var url = "../Ashx/test.ashx";     customAjax("get",url,["title"],[obj.value],handleresponse);  }

       說明一下,customAjax就是封裝的對外提供的調用方法,第一參數是提交資料的方式,get或者post;第二個是提交的地址;第三個和第四個是數組,是要提交資料,第一個數組裝鍵,後一個裝值,必須相對應;最後一個就是回呼函數了,自己定義。

       調用還不算太麻煩,可能看來不太物件導向而已,不太習慣。

      下面上代碼:

//  建立xmlhttp對象function CreateXMLHTTP(){   var XMLHTTP;   if(window.ActiveXObject)   {       var arrSignature = ["MSXML2.XMLHTTP.6.0",“MSXML2.XMLHTTP.5.0",”MSXML2.XMLHTTP.4.0","MSXML2.XMLHTTP.3.0","MSXML2.XMLHTTP","Microsot.XMLHTTP"];       for(var i=0;i<arrSignature.length;i++)         {             try             {             XMLHTTP = new ActiveXObject(arrSignature[i]);             return XMLHTTP;             }             catch(oException)             {             }        }       throw new Error("MSXML is not installed on your IE.");   }   else if(window.XMLHttpRequest)   {        XMLHTTP = new XMLHttpRequest();        return XMLHTTP;   }} function addGETParam(sUrl,sParamName,sParamValue){   sUrl += ( sUrl.indexOf("?") == -1 ? "?" : "&");   sUrl += escape(sParamName) + "=" + escape(sParamValue);   return sUrl;}function addPOSTParam(sParams,sParamName,sParamValue){   sParams += ( sParams.length > 0 ? "&" : "" );   sParams += escape(sParamName) + "=" + escape(sParamValue);   return sParams;}//  主要的方法function customAjax(sType,sUrl,arrParamName,arrParamValue,funStateChange){    var XMLHTTP = CreateXMLHTTP();       var sParams = "";    if( arrParamName instanceof Array && arrParamValue instanceof Array)    {       if(arrParamName.length == arrParamValue.length)       {            if(sType.toLowerCase() == "get")            {               sParams = null;              for(var i=0;i<arrParamName.length;i++)                 sUrl = addGETParam(sUrl,arrParamName[i],arrParamValue[i]);            }            else if(sType.toLowerCase() == "post")            {                for(var i=0;i<arrParamName.length;i++)                     sParams = addPOSTParam(sParams,arrParamName[i],arrParamValue[i]);            }         }          else       {          throw new Error("Two parma Array's length is not same.");       }    }    else    {       throw new Error("The third and fourth param must be Array.");    }    XMLHTTP.open(sType.toUpperCase(),sUrl,true);    if(funStateChange instanceof Function)   {        XMLHTTP.onreadystatechange =  function(){funStateChange(XMLHTTP);}  }    else    { throw new Error("the last param must be Function."); }    XMLHTTP.send(sParams);            }

     就是這麼多,還不少,有一點要說是

["MSXML2.XMLHTTP.6.0",“MSXML2.XMLHTTP.5.0",”MSXML2.XMLHTTP.4.0","MSXML2.XMLHTTP.3.0","MSXML2.XMLHTTP","Microsot.XMLHTTP"]

     在支援ie標準的瀏覽器上,有的電腦有可能會彈出讓你載入MSXML2.XMLHTTP.6.0的提示,因為你的瀏覽器可能沒有載入這個控制項;如果你對自己的網站在使用者電腦上這個提示不能容忍,那就把這個版本的檢測從這個數組中刪除,一般情況下,刪除到4.0時,IE瀏覽器就不會有載入的提示了。如果你還不放心,仍可以繼續刪除到只剩下Microsot.XMLHTTP,其中jquery-1.3.2就是這樣,以下是這個版本的jquery代碼:

xhr:function(){return window.ActiveXObject ? new ActiveXObject("Microsoft.XMLHTTP") : new XMLHttpRequest();},

當然你如果嫌上面的建立過程太煩瑣,也可以採用jquery這種方式。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.