實例講解使用原生JavaScript處理AJAX請求的方法
Ajax 是異步的JavaScript和XML的簡稱,是一種更新頁面某部分的機(jī)制。它賦予了你從服務(wù)器獲取數(shù)據(jù)后,更新頁面某部分的權(quán)力,從而避免了刷新整個頁面。另外,以此方式實現(xiàn)頁面局部更新,不僅能有效地打造流暢的用戶體驗,而且減輕了服務(wù)器的負(fù)載。
下面是對一個基本的 Ajax 請求進(jìn)行剖析:
var xhr = new XMLHttpRequest();
xhr.open('GET', 'send-ajax-data.php');
xhr.send(null);
在這里, 我們創(chuàng)建了一個能向服務(wù)器發(fā)出 HTTP 請求的類的實例。然后調(diào)用其 open 方法,其中第一個參數(shù)是 HTTP 請求方法,第二個參數(shù)是請求頁面的 URL。最后,我們調(diào)用參數(shù)為 null 的 send 方法。假如使用 POST 請求方法(這里我們使用了 GET),那么 send 方法 的參數(shù)應(yīng)該包含任何你想發(fā)送的數(shù)據(jù)。
下面是我們?nèi)绾翁幚矸?wù)器的響應(yīng):
xhr.onreadystatechange = function(){
var DONE = 4; // readyState 4 代表已向服務(wù)器發(fā)送請求
var OK = 200; // status 200 代表服務(wù)器返回成功
if(xhr.readyState === DONE){
if(xhr.status === OK){
console.log(xhr.responseText); // 這是返回的文本
} else{
console.log("Error: "+ xhr.status); // 在此次請求中發(fā)生的錯誤
}
}
}
onreadystatechange 是異步的,那么這就意味著它將可在任何時候被調(diào)用。這種類型的函數(shù)被稱為回調(diào)函數(shù)——一旦某些處理完成后,它就會被調(diào)用。在此案例中,這個處理發(fā)生在服務(wù)器。
示例
便捷的 Ajax 方法也是不少人依賴 jQuery 的原因,但實際上原生 JavaScript 的 Ajax api 也很強(qiáng)大,并且基本的使用在各個瀏覽器中的差異不大,因此完全可以自行封裝一個 Ajax 對象,下面是封裝好的 Ajax 對象:
// Ajax 方法
// 惰性載入創(chuàng)建 xhr 對象
function createXHR(){
if ( 'XMLHttpRequest' in window ){
createXHR = function(){
return new XMLHttpRequest();
};
} else if( 'ActiveXObject' in window ){
createXHR = function(){
return new ActiveXObject("Msxml2.XMLHTTP");
};
} else {
createXHR = function(){
throw new Error("Ajax is not supported by this browser");
};
}
return createXHR();
}
// Ajax 執(zhí)行
function request(ajaxData){
var xhr = createXHR();
ajaxData.before && ajaxData.before();
// 通過事件來處理異步請求
xhr.onreadystatechange = function(){
if( xhr.readyState == 4 ){
if( xhr.status == 200 ){
if( ajaxData.dataType == 'json' ){
// 獲取服務(wù)器返回的 json 對象
jsonStr = xhr.responseText;
json1 = eval('(' + jsonStr + ')'),
json2 = (new Function('return ' + jsonStr))();
ajaxData.callback(json2);
// ajaxData.callback(JSON.parse(xhr.responseText)); // 原生方法,IE6/7 不支持
} else
ajaxData.callback(xhr.responseText);
} else {
ajaxData.error && ajaxData.error(xhr.responseText);
}
}
};
// 設(shè)置請求參數(shù)
xhr.open(ajaxData.type, ajaxData.url);
if( ajaxData.noCache == true ) xhr.setRequestHeader('If-Modified-Since', '0');
if( ajaxData.data ){
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
xhr.send( ajaxData.data );
} else {
? ?
xhr.setRequestHeader('X-Requested-With', 'XMLHttpRequest');
xhr.send( null );
}
return xhr;
}
function post(ajaxData){
ajaxData.type = 'POST';
var _result = request(ajaxData);
return _result;
}
function get(ajaxData){
ajaxData.type = 'GET';
ajaxData.data = null;
var _result = request(ajaxData);
return _result;
}
下面給出一個使用例子:
index.html
<!DOCTYPE HTML>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<title>原生 JavaScript 實現(xiàn) Ajax</title>
<link rel="stylesheet" type="text/css" media="all" href="./common/common.css" />
<style>
#content {text-align: center; font-family: 'lucida Grande', 'Microsoft Yahei'}
#content .btn_ctr {display: block; width: 120px; height: 30px; margin: 0 auto 20px; background: #53a7bb; color: #fff; font-weight: bold; font-size: 14px; line-height: 30px; text-decoration: none;
border-radius: 4px;
}
#test {width: 280px; height: 130px; margin: 0 auto; padding: 15px; background: #fff; border-radius: 4px; text-align: left; }
</style>
</head>
<body>
<div id="header">
<div id="header-content">
<div id="header-inside">
<p class="go-to-article"><a title="打開原文" target="_blank" >Back To Article</a></p>
<p class="go-to-blog"><a title="進(jìn)入我的博客 Kayo's Melody" target="_blank" >My Blog</a></p>
<p class="copyright">Demo By Kayo © Copyright 2011-2013</p>
</div>
<h1>CSS3 Animation</h1>
</div>
</div>
<div id="content">
<a class="btn_ctr" href="javascript:;" onclick="get({url: './ajax.html', callback: function(out){document.getElementById('test').innerHTML = out;}})">Ajax 獲取內(nèi)容</a>
<div id="test"></div>
</div>
<script>
// Ajax 方法,這里不在重復(fù)列出
</script>
</body>
</html>
<!DOCTYPE HTML> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>ajax</title> </head> <body> <p>成功獲取到這段文本</p> </body> </html>
具體的效果可以瀏覽完整 Demo 。
- 原生js jquery ajax請求以及jsonp的調(diào)用方法
- 詳解JavaScript原生封裝ajax請求和Jquery中的ajax請求
- 原生javascript的ajax請求及后臺PHP響應(yīng)操作示例
- Javascript原生ajax請求代碼實例
- 輕松搞定jQuery+JSONP跨域請求的解決方案
- JavaScript用JSONP跨域請求數(shù)據(jù)實例詳解
- Ajax jsonp跨域請求實現(xiàn)方法
- JSONP跨域請求實例詳解
- 詳細(xì)解密jsonp跨域請求
- JSONP跨域請求
- jsonp跨域請求實現(xiàn)示例
- 原生js實現(xiàn)ajax請求和JSONP跨域請求操作示例
相關(guān)文章
腳本之家貼圖轉(zhuǎn)換+轉(zhuǎn)貼工具用到的js代碼超級推薦
[紅色]腳本之家貼圖轉(zhuǎn)換+轉(zhuǎn)貼工具用到的js代碼超級推薦...2007-04-04
JS模擬實現(xiàn)ECMAScript5新增的數(shù)組方法
ECMAScript5 新增了十個數(shù)組方法,這些方法只有在ie9及以上瀏覽器中可以被使用,下面是對于這些方法的模擬實現(xiàn)簡單介紹下,需要的朋友參考下2017-03-03
通過JavaScript實現(xiàn)CSS和JS文件的動態(tài)加載
在現(xiàn)代Web開發(fā)中,動態(tài)加載CSS和JavaScript文件是一個常見的需求,這種技術(shù)可以用來優(yōu)化頁面加載速度,減少初始加載時間,并提高用戶體驗,本文將詳細(xì)介紹如何通過JavaScript實現(xiàn)CSS和JS文件的動態(tài)加載,包括不同的加載方法、注意事項以及最佳實踐2024-11-11
利用NodeJS和PhantomJS抓取網(wǎng)站頁面信息以及網(wǎng)站截圖
這篇文章主要介紹了利用NodeJS和PhantomJS抓取網(wǎng)站頁面信息以及網(wǎng)站截圖的方法,提供實例代碼供大家參考2013-11-11
javascript小數(shù)計算出現(xiàn)近似值的解決辦法
在javascript里面,小數(shù)只能進(jìn)行相似計算,例如:5.06+1.30,你得到的結(jié)果會是6.359999999999999,但有的小數(shù)計算又是正確的,如果計算出現(xiàn)了近似值,你可以用如下的方法計算。2010-02-02

