国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > AJAX > 正文

關于Ajax的原理以及代碼封裝詳解

2024-09-01 08:33:53
字體:
來源:轉載
供稿:網友

前言

其實AJAX內部實現并不麻煩,主要通過一個叫XMLHttpRequest的對象,而這個對象在現有的瀏覽器均被支持。

可以說,它是整個AJAX實現的基礎,是瀏覽器用于后臺與服務器交換數據的對象,有了它,才有了AJAX,也便有了部分頁面刷新的藝術!

本文主要給大家介紹了關于Ajax原理以及代碼封裝的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。

示例代碼

var xmlhttp;if (window.XMLHttpRequest) { // code for IE7+, Firefox, Chrome, Opera, Safari xmlhttp = new XMLHttpRequest();} else { // code for IE6, IE5  xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");}xmlhttp.onreadystatechange = function() { if (xmlhttp.readyState == 4 && xmlhttp.status == 200){  // to do... }}xmlhttp.open("GET","test1.txt",true);xmlhttp.send();

步驟:

1、創建。

創建 XMLHttpRequest 對象的語法:

var = new XMLHttpRequest();

老版本的 Internet Explorer (IE5 和 IE6)使用 ActiveX 對象:

var = new ActiveXObject("Microsoft.XMLHTTP");

2、連接和發送。

2.1、open()函數的三個參數:請求方式、請求地址、是否異步請求

2.2、GET 請求方式是通過URL參數將數據提交到服務器的,POST則是通過將數據作為 send 的參數提交到服務器

2.3、POST 請求中,在發送數據之前,要設置表單提交的內容類型

2.3、提交到服務器的參數必須經過 encodeURIComponent() 方法進行編碼,實際上在參數列表key=value的形式中,key 和 value 都需要進行編碼,因為會包含特殊字符。每次請求的時候都會在參數列表中拼入一個 v=xx 的字符串,這樣是為了拒絕緩存,每次都直接請求到服務器上。

3、接收。

3.1、接收到響應后,響應的數據會自動填充XHR對象,相關屬性如下

responseText:響應返回的主體內容,為字符串類型;

responseXML:如果響應的內容類型是 "text/xml" 或 "application/xml",這個屬性中將保存著相應的xml 數據,是 XML 對應的 document 類型;

status:響應的HTTP狀態碼;

statusText:HTTP狀態的說明

3.2、XHR對象的readyState屬性表示請求/響應過程的當前活動階段,這個屬性的值如下

0 --> 未初始化,尚未調用open()方法;

1 --> 啟動,調用了open()方法,未調用send()方法;

2 --> 發送,已經調用了send()方法,未接收到響應;

3 --> 接收,已經接收到部分響應數據;

4 --> 完成,已經接收到全部響應數據;

只要 readyState 的值變化,就會調用 readystatechange 事件,(其實為了邏輯上通順,可以把readystatechange放到send之后,因為send時請求服務器,會進行網絡通信,需要時間,在send之后指定readystatechange事件處理程序也是可以的,我一般都是這樣用,但為了規范和跨瀏覽器兼容性,還是在open之前進行指定吧)。

3.3、在readystatechange事件中,先判斷響應是否接收完成,然后判斷服務器是否成功處理請求,xhr.status 是狀態碼,狀態碼以2開頭的都是成功,304表示從緩存中獲取,上面的代碼在每次請求的時候都加入了隨機數,所以不會從緩存中取值,故該狀態不需判斷。

封裝ajax方法:

 ajax({    url: "./test.php",  type: "POST",        data: { name: "abc", age: 18 },     dataType: "json",    success: function (response, xml) {      // 執行成功回調    },    fail: function (status) {      // 執行失敗回調    } });    function ajax(options) {    options = options || {};    options.type = (options.type || "GET").toUpperCase();     options.dataType = options.dataType || "json";     var params = formatParams(options.data);          // 創建對象     if (window.XMLHttpRequest) {       var xhr = new XMLHttpRequest();    } else {       var xhr = new ActiveXObject('Microsoft.XMLHTTP');     }       //接收 - 第三步   xhr.onreadystatechange = function () {       if (xhr.readyState == 4) {         var status = xhr.status;         if (status >= 200 && status < 300) {           options.success && options.success(xhr.responseText,xhr.responseXML);         } else {           options.fail && options.fail(status);         }       }   }         //連接 和 發送 - 第二步    if (options.type == "GET") {       xhr.open("GET", options.url + "?" + params, true);       xhr.send(null);     } else if (options.type == "POST") {       xhr.open("POST", options.url, true);       //設置表單提交時的內容類型       xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");    xhr.send(params);     }        //格式化參數    function formatParams(data) {     var arr = [];      for (var name in data) {        arr.push(encodeURIComponent(name) + "=" + encodeURIComponent(data[name]));     }      arr.push(("v=" + Math.random()).replace(".",""));      return arr.join("&");    }

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 克拉玛依市| 哈巴河县| 珲春市| 江阴市| 南京市| 锦屏县| 达日县| 广昌县| 定陶县| 十堰市| 康乐县| 阳泉市| 松阳县| 大同市| 峡江县| 沙田区| 江陵县| 化州市| 安达市| 昌图县| 隆安县| 西藏| 汝城县| 巧家县| 平罗县| 宜城市| 临沂市| 平塘县| 天祝| 静宁县| 腾冲县| 东源县| 光山县| 长丰县| 明光市| 兴仁县| 墨江| 呼和浩特市| 普兰县| 台北县| 浦东新区|