實(shí)例講解使用原生JavaScript處理AJAX請(qǐng)求的方法
Ajax 是異步的JavaScript和XML的簡稱,是一種更新頁面某部分的機(jī)制。它賦予了你從服務(wù)器獲取數(shù)據(jù)后,更新頁面某部分的權(quán)力,從而避免了刷新整個(gè)頁面。另外,以此方式實(shí)現(xiàn)頁面局部更新,不僅能有效地打造流暢的用戶體驗(yàn),而且減輕了服務(wù)器的負(fù)載。
下面是對(duì)一個(gè)基本的 Ajax 請(qǐng)求進(jìn)行剖析:
var xhr = new XMLHttpRequest(); xhr.open('GET', 'send-ajax-data.php'); xhr.send(null);
在這里, 我們創(chuàng)建了一個(gè)能向服務(wù)器發(fā)出 HTTP 請(qǐng)求的類的實(shí)例。然后調(diào)用其 open 方法,其中第一個(gè)參數(shù)是 HTTP 請(qǐng)求方法,第二個(gè)參數(shù)是請(qǐng)求頁面的 URL。最后,我們調(diào)用參數(shù)為 null 的 send 方法。假如使用 POST 請(qǐng)求方法(這里我們使用了 GET),那么 send 方法 的參數(shù)應(yīng)該包含任何你想發(fā)送的數(shù)據(jù)。
下面是我們?nèi)绾翁幚矸?wù)器的響應(yīng):
xhr.onreadystatechange = function(){ var DONE = 4; // readyState 4 代表已向服務(wù)器發(fā)送請(qǐng)求 var OK = 200; // status 200 代表服務(wù)器返回成功 if(xhr.readyState === DONE){ if(xhr.status === OK){ console.log(xhr.responseText); // 這是返回的文本 } else{ console.log("Error: "+ xhr.status); // 在此次請(qǐng)求中發(fā)生的錯(cuò)誤 } } }
onreadystatechange 是異步的,那么這就意味著它將可在任何時(shí)候被調(diào)用。這種類型的函數(shù)被稱為回調(diào)函數(shù)——一旦某些處理完成后,它就會(huì)被調(diào)用。在此案例中,這個(gè)處理發(fā)生在服務(wù)器。
示例
便捷的 Ajax 方法也是不少人依賴 jQuery 的原因,但實(shí)際上原生 JavaScript 的 Ajax api 也很強(qiáng)大,并且基本的使用在各個(gè)瀏覽器中的差異不大,因此完全可以自行封裝一個(gè) Ajax 對(duì)象,下面是封裝好的 Ajax 對(duì)象:
// Ajax 方法 // 惰性載入創(chuàng)建 xhr 對(duì)象 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(); // 通過事件來處理異步請(qǐng)求 xhr.onreadystatechange = function(){ if( xhr.readyState == 4 ){ if( xhr.status == 200 ){ if( ajaxData.dataType == 'json' ){ // 獲取服務(wù)器返回的 json 對(duì)象 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è)置請(qǐng)求參數(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; }
下面給出一個(gè)使用例子:
index.html
<!DOCTYPE HTML> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>原生 JavaScript 實(shí)現(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請(qǐng)求以及jsonp的調(diào)用方法
- 詳解JavaScript原生封裝ajax請(qǐng)求和Jquery中的ajax請(qǐng)求
- 原生javascript的ajax請(qǐng)求及后臺(tái)PHP響應(yīng)操作示例
- Javascript原生ajax請(qǐng)求代碼實(shí)例
- 輕松搞定jQuery+JSONP跨域請(qǐng)求的解決方案
- JavaScript用JSONP跨域請(qǐng)求數(shù)據(jù)實(shí)例詳解
- Ajax jsonp跨域請(qǐng)求實(shí)現(xiàn)方法
- JSONP跨域請(qǐng)求實(shí)例詳解
- 詳細(xì)解密jsonp跨域請(qǐng)求
- JSONP跨域請(qǐng)求
- jsonp跨域請(qǐng)求實(shí)現(xiàn)示例
- 原生js實(shí)現(xiàn)ajax請(qǐng)求和JSONP跨域請(qǐng)求操作示例
相關(guān)文章
JS隨機(jī)生成不重復(fù)數(shù)據(jù)的實(shí)例方法
這篇文章介紹了JS隨機(jī)生成不重復(fù)數(shù)據(jù)的實(shí)例方法,有需要的朋友可以參考一下2013-07-07JS圖片懶加載技術(shù)實(shí)現(xiàn)過程解析
這篇文章主要介紹了JS圖片懶加載技術(shù)實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07js實(shí)用技巧之去除數(shù)組或者對(duì)象里重復(fù)選項(xiàng)
這篇文章主要給大家介紹了關(guān)于js實(shí)用技巧之去除數(shù)組或者對(duì)象里重復(fù)選項(xiàng)的相關(guān)資料,JavaScript數(shù)組有很多內(nèi)置方法,可以操作和處理數(shù)據(jù),文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2023-08-08跟我學(xué)習(xí)javascript的垃圾回收機(jī)制與內(nèi)存管理
跟我學(xué)習(xí)javascript的垃圾回收機(jī)制與內(nèi)存管理,感興趣的小伙伴們可以參考一下2015-11-11JS獲得一個(gè)對(duì)象的所有屬性和方法實(shí)例
下面小編就為大家?guī)硪黄狫S獲得一個(gè)對(duì)象的所有屬性和方法實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02JS驗(yàn)證IP,子網(wǎng)掩碼,網(wǎng)關(guān)和MAC的方法
這篇文章主要介紹了JS驗(yàn)證IP,子網(wǎng)掩碼,網(wǎng)關(guān)和MAC的方法,涉及javascript正則表達(dá)式的相關(guān)使用技巧,需要的朋友可以參考下2015-07-07