什么是Ajax
Ajax是Asynchronous JavaScript and XML的縮寫,這一技術(shù)能夠向服務(wù)器請求額外的數(shù)據(jù)而無需卸載整個頁面,會帶來良好的用戶體驗。傳統(tǒng)的HTTP請求流程大概是這樣的,瀏覽器向服務(wù)器發(fā)送請求-〉服務(wù)器根據(jù)瀏覽器傳來數(shù)據(jù)生成response-〉服務(wù)器把response返回給瀏覽器-〉瀏覽器刷新整個頁面顯示最新數(shù)據(jù),這個過程是同步的,順序執(zhí)行。
AJAX 在瀏覽器與 Web 服務(wù)器之間使用異步數(shù)據(jù)傳輸(HTTP 請求)從服務(wù)器獲取數(shù)據(jù),這里的異步是指脫離當(dāng)前瀏覽器頁面的請求、加載等單獨執(zhí)行,這意味著可以在不重新加載整個網(wǎng)頁的情況下,通過JavaScript接受服務(wù)器傳來的數(shù)據(jù),然后操作DOM將新數(shù)據(jù)對網(wǎng)頁的某部分進行更新,使用Ajax最直觀的感受是向服務(wù)器獲取新數(shù)據(jù)不需要刷新頁面等待了。
ajax的理解(一)
Ajax是Asynchronous Javascript And XML的縮寫。 作用:通過Ajax可以使用Javascript語句來調(diào)用XMLHttpRequest對象,直接與服務(wù)器進行通訊,可以在不重載頁面的情況下與服務(wù)器交換數(shù)據(jù)。 1、創(chuàng)建XML
Ajax是Asynchronous Javascript And XML的縮寫。
作用:通過Ajax可以使用Javascript語句來調(diào)用XMLHttpRequest對象,直接與服務(wù)器進行通訊,可以在不重載頁面的情況下與服務(wù)器交換數(shù)據(jù)。
1、創(chuàng)建XMLHttpRequest對象
var xhr = new XMLHttpRequest()
對于IE早期版本(IE7及以下版本)使用,new ActiveXObject(\"Microsoft.XMLHTTP\")、new ActiveXObject(\"Msxml2.XMLHTTP\")等方式創(chuàng)建對象
2、XMLHttpRequest對象常用屬性和常用方法
屬性
readystate 返回XMLHTTP請求的當(dāng)前狀態(tài)碼
state 返回當(dāng)前請求的HTTP狀態(tài)碼
statusText 返回HTTP狀態(tài)碼對應(yīng)的文本
方法
onreadystatechange 監(jiān)聽readystate和state狀態(tài)
ajax的理解(二)
ajax方法:通過 HTTP 請求加載遠(yuǎn)程數(shù)據(jù)
get方法: 通過遠(yuǎn)程 HTTP GET 請求載入信息
post方法:通過遠(yuǎn)程 HTTP POST 請求載入信息
1、創(chuàng)建XMLHttpRequest對象
function createXHR() {
return window.XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHTTP");
}
2、將鍵值對轉(zhuǎn)換成拼接串
function params(data) {
var a = [];
for (var i in data) {
a.push(encodeURIComponent(i) + "=" + encodeURIComponent(data[i]));
}
return a.join("");
}
3、封裝ajax方法
參數(shù)
method 請求方法 get和post 默認(rèn)get
data 鍵值對 {key:value}
url 鏈接地址
cache 緩存 true 和 false 默認(rèn)true帶緩存
success 成功 error 異常
function ajax(args) {
var xhr = createXHR();
var data = http://www.cnblogs.com/kuikui/archive/2012/01/12/params(args.data);
if (/get/i.test(args.method)) { // 當(dāng)為get方式時 將data直接拼接到url后
args.url += "?" + data;
}
if (!args.cache) { //無緩存
if (args.url.indexOf("?") 0) { //當(dāng)無參數(shù)data
args.url += "?";
}
args.url += "" + (new Date()); // Math.random();
}
xhr.open(args.method, args.url, true);
xhr.onreadystatechange = function () {
if (4 == xhr.readyState 200 == xhr.status) {
args.success(xhr.responseText, xhr.responseXML);
}
else {
args.error();
}
}
if (/post/i.test(args.method)) {
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xhr.send(data);
}
else {
xhr.send();
您可能感興趣的文章:- AJAX入門之深入理解JavaScript中的函數(shù)
- AJAX入門之深入理解JavaScript中的函數(shù)
- 看圖理解 普通交互方式和Ajax交互方式區(qū)別
- Ajax工作原理深入理解
- 用iframe設(shè)置代理解決ajax跨域請求問題
- jquery的ajax同步和異步的理解及示例
- ajax的get請求時緩存處理解決方法
- 理解jquery ajax中的datatype屬性選項值