国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

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

來源:懂視網 責編:小采 時間:2020-11-27 22:30:48
文檔

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

關于Ajax的原理以及代碼封裝詳解:前言 其實AJAX內部實現并不麻煩,主要通過一個叫XMLHttpRequest的對象,而這個對象在現有的瀏覽器均被支持。 可以說,它是整個AJAX實現的基礎,是瀏覽器用于后臺與服務器交換數據的對象,有了它,才有了AJAX,也便有了部分頁面刷新的藝術! 本文主要給大家介
推薦度:
導讀關于Ajax的原理以及代碼封裝詳解:前言 其實AJAX內部實現并不麻煩,主要通過一個叫XMLHttpRequest的對象,而這個對象在現有的瀏覽器均被支持。 可以說,它是整個AJAX實現的基礎,是瀏覽器用于后臺與服務器交換數據的對象,有了它,才有了AJAX,也便有了部分頁面刷新的藝術! 本文主要給大家介

前言

其實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("&"); 
 }

總結

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

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

關于Ajax的原理以及代碼封裝詳解:前言 其實AJAX內部實現并不麻煩,主要通過一個叫XMLHttpRequest的對象,而這個對象在現有的瀏覽器均被支持。 可以說,它是整個AJAX實現的基礎,是瀏覽器用于后臺與服務器交換數據的對象,有了它,才有了AJAX,也便有了部分頁面刷新的藝術! 本文主要給大家介
推薦度:
標簽: 原理 代碼 ajax
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产一区二区高清视频 | 国产成人精品久久亚洲高清不卡 | 日韩在线观看视频网站 | 欧美日在线观看 | 国产成人精品日本亚洲语音2 | 国产精品一区二区三区四区 | 国产一区二区不卡 | 九九热免费视频 | 韩国精品一区 | 久久精品国产一区二区三区 | 欧美精品一区二区三区四区 | 在线观看免费国产视频 | 国产在线视频不卡 | 国内精品久久久久久久97牛牛 | 日韩欧美系列 | 国产成人一区二区三区影院免费 | 五月激情综合网 | 国产主播一区 | 免费视频国产 | 国产视频高清在线观看 | 国产高清不卡码一区二区三区 | 91精品成人免费国产片 | 91久久精品一区二区三区 | 亚洲欧美日韩综合网导航 | 国产一级片免费观看 | 美女网站全黄 | 欧美成人高清在线视频大全 | 欧美高清亚洲欧美一区h | 久久久久久久一精品 | 国产成人在线看 | 国产欧美日韩一区 | 国产八区| 免费观看a毛片一区二区不卡 | 欧美日韩精品一区二区 | 国产 日韩 欧美 亚洲 | 亚洲精品在线免费观看 | 欧洲日韩视频二区在线 | 国内精品1区1区3区4区 | 国产区精品在线 | 国产丝袜在线视频 | 综合精品欧美日韩国产在线 |