亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 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教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美日韩中文视频| 久久香蕉频线观| 91在线免费看网站| 亚洲sss综合天堂久久| 国产欧美日韩高清| 亚洲欧美精品一区| 亚洲欧洲一区二区三区久久| 欧美国产在线视频| 国产精品色午夜在线观看| 奇米一区二区三区四区久久| 欧美性猛交xxxx| 亚洲精品av在线播放| 亚洲欧美一区二区三区四区| 国产欧美欧洲在线观看| 国产成人精彩在线视频九色| 亚洲人成网站777色婷婷| 亚洲第一二三四五区| 国产精品人人做人人爽| 91爱爱小视频k| 亚洲精品视频二区| 亚洲丁香婷深爱综合| 日本久久中文字幕| 午夜精品在线观看| 国产精品∨欧美精品v日韩精品| 欧美激情18p| 国产精品色午夜在线观看| 欧美一级成年大片在线观看| 国产精品永久免费在线| 亚洲欧美日韩视频一区| 91av在线国产| 91亚洲精品久久久| 亚洲国产精彩中文乱码av| 日韩av手机在线看| 91精品视频在线播放| 日韩亚洲精品视频| 国产午夜精品一区二区三区| 亚洲最大福利网| 伊人一区二区三区久久精品| 国产精品欧美日韩| 久久伊人精品一区二区三区| 色偷偷av一区二区三区| 77777亚洲午夜久久多人| 亚洲视频在线看| 欧美精品18videos性欧| 亚洲国产日韩欧美在线图片| 欧美巨乳在线观看| 91精品国产色综合久久不卡98口| 国产69精品久久久久99| 欧美成人免费一级人片100| 国产不卡av在线| 久久精品夜夜夜夜夜久久| 欧美重口另类videos人妖| 在线视频国产日韩| 精品国产一区二区三区在线观看| 国产一区二区三区视频免费| 欧美精品免费在线观看| 亚洲国产精品系列| 成人免费直播live| 97在线视频观看| 亚洲国产高清自拍| 国产精品成人一区二区三区吃奶| 国产精品一区二区三区成人| 日韩av在线精品| 欧美福利视频在线观看| 97人洗澡人人免费公开视频碰碰碰| 国产亚洲a∨片在线观看| 精品五月天久久| 日本一区二三区好的精华液| 欧美重口另类videos人妖| 亚洲成人激情小说| 国产综合久久久久久| 97视频在线观看视频免费视频| 国产成人福利网站| 欧美成人黑人xx视频免费观看| 久久免费视频在线| 97在线视频免费播放| 亚洲美女在线看| 日韩国产一区三区| 国产91色在线| 亚洲在线免费看| 91美女片黄在线观| 欧美尺度大的性做爰视频| 亚洲成人久久久| 2019最新中文字幕| 色婷婷**av毛片一区| 亚洲a级在线播放观看| 亚洲欧洲av一区二区| 欧美性猛交xxxx免费看久久久| 久久久久久久久久久免费精品| 亚洲精品自拍第一页| 国产精品久久久久9999| 日韩视频欧美视频| 久久久久久亚洲精品不卡| 亚洲国产中文字幕在线观看| 91免费看国产| 欧美一区二区三区免费视| 亚洲成人教育av| 日韩美女福利视频| 欧美专区福利在线| 中文国产成人精品| 国产日韩欧美中文在线播放| 国产在线精品一区免费香蕉| 欧美视频13p| 亚洲国产精品女人久久久| 精品久久久久国产| 国产精品三级在线| 中文字幕亚洲欧美一区二区三区| 亚洲综合成人婷婷小说| 国产999精品视频| 这里只有精品视频在线| 欧美一乱一性一交一视频| 一区三区二区视频| 911国产网站尤物在线观看| 亚洲天堂视频在线观看| 精品免费在线观看| 国产精品爱啪在线线免费观看| 国产自产女人91一区在线观看| 国产一区二区成人| 亚洲欧美日韩第一区| 欧美性在线视频| 91精品国产综合久久香蕉| 色小说视频一区| 久久久国产精品免费| …久久精品99久久香蕉国产| 久久久久久亚洲精品不卡| 欧美美女18p| 国产成人一区二区在线| 日韩视频免费中文字幕| 久久久久国产一区二区三区| 亚洲人成伊人成综合网久久久| 国产精品视频xxx| 国产精品久久久久一区二区| 亚洲欧美日本精品| 亚洲一区二区免费在线| 国产精品影片在线观看| 亚洲图片欧洲图片av| 欧美日韩一区二区三区在线免费观看| 欧美日韩国产综合视频在线观看中文| 91av在线免费观看| 5252色成人免费视频| 神马国产精品影院av| 欧美视频在线免费| 欧美国产在线电影| 国产性色av一区二区| 中文字幕亚洲欧美一区二区三区| 久久久999精品| 国产精品久久久久久久午夜| 97视频免费在线看| 亚洲午夜未删减在线观看| 欧美一级成年大片在线观看| 亚洲成人久久一区| 夜夜嗨av一区二区三区免费区| 97超碰国产精品女人人人爽| 欧美人与性动交a欧美精品| 国内精品视频一区| 日本国产欧美一区二区三区| 777777777亚洲妇女| 亚洲视频在线观看| 亚洲欧美日韩一区二区在线| 91国产一区在线| 国产精品99久久久久久白浆小说| 精品综合久久久久久97| 国产成人精品综合| 精品国内产的精品视频在线观看|