欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

實例講解使用原生JavaScript處理AJAX請求的方法

 更新時間:2016年05月10日 16:25:10   作者:Kayo Lee  
這篇文章主要介紹了實例講解使用原生JavaScript處理AJAX請求的方法,這樣就算是利用原生API而脫離了jQuery中的Ajax方法,需要的朋友可以參考下

Ajax 是異步的JavaScript和XML的簡稱,是一種更新頁面某部分的機制。它賦予了你從服務(wù)器獲取數(shù)據(jù)后,更新頁面某部分的權(quán)力,從而避免了刷新整個頁面。另外,以此方式實現(xiàn)頁面局部更新,不僅能有效地打造流暢的用戶體驗,而且減輕了服務(wù)器的負(fù)載。

下面是對一個基本的 Ajax 請求進行剖析:

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 也很強大,并且基本的使用在各個瀏覽器中的差異不大,因此完全可以自行封裝一個 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="進入我的博客 Kayo's Melody" target="_blank" >My Blog</a></p>
    <p class="copyright">Demo By Kayo &copy; 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>

ajax.html
<!DOCTYPE HTML>
<html lang="zh-CN">
<head>
 <meta charset="UTF-8">
 <title>ajax</title>
</head>
<body>
 <p>成功獲取到這段文本</p>
</body>
</html>

具體的效果可以瀏覽完整 Demo 。


相關(guān)文章

  • 淺析js的模塊化編寫 require.js

    淺析js的模塊化編寫 require.js

    requirejs是一個JavaScript文件和模塊加載器。requireJS允許你把你的javascript代碼獨立成文件和模塊,同時管理每個模塊間的依賴關(guān)系。本文主要對require.js的使用與工作原理進行系統(tǒng)介紹。需要的朋友來看下吧
    2016-12-12
  • JS隨機生成不重復(fù)數(shù)據(jù)的實例方法

    JS隨機生成不重復(fù)數(shù)據(jù)的實例方法

    這篇文章介紹了JS隨機生成不重復(fù)數(shù)據(jù)的實例方法,有需要的朋友可以參考一下
    2013-07-07
  • 微信小程序中視頻的顯示與隱藏功能

    微信小程序中視頻的顯示與隱藏功能

    這篇文章主要介紹了微信小程序中視頻的顯示與隱藏,思路大概是定義一個標(biāo)記變量,控制視頻的播放與暫停,本文結(jié)合實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-10-10
  • JS圖片懶加載技術(shù)實現(xiàn)過程解析

    JS圖片懶加載技術(shù)實現(xiàn)過程解析

    這篇文章主要介紹了JS圖片懶加載技術(shù)實現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07
  • js實用技巧之去除數(shù)組或者對象里重復(fù)選項

    js實用技巧之去除數(shù)組或者對象里重復(fù)選項

    這篇文章主要給大家介紹了關(guān)于js實用技巧之去除數(shù)組或者對象里重復(fù)選項的相關(guān)資料,JavaScript數(shù)組有很多內(nèi)置方法,可以操作和處理數(shù)據(jù),文中通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08
  • javascript原型模式用法實例詳解

    javascript原型模式用法實例詳解

    這篇文章主要介紹了javascript原型模式用法,以實例形式較為詳細(xì)的分析了javascript原型模式的原理與使用技巧,需要的朋友可以參考下
    2015-06-06
  • 跟我學(xué)習(xí)javascript的垃圾回收機制與內(nèi)存管理

    跟我學(xué)習(xí)javascript的垃圾回收機制與內(nèi)存管理

    跟我學(xué)習(xí)javascript的垃圾回收機制與內(nèi)存管理,感興趣的小伙伴們可以參考一下
    2015-11-11
  • JS獲得一個對象的所有屬性和方法實例

    JS獲得一個對象的所有屬性和方法實例

    下面小編就為大家?guī)硪黄狫S獲得一個對象的所有屬性和方法實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • JS驗證IP,子網(wǎng)掩碼,網(wǎng)關(guān)和MAC的方法

    JS驗證IP,子網(wǎng)掩碼,網(wǎng)關(guān)和MAC的方法

    這篇文章主要介紹了JS驗證IP,子網(wǎng)掩碼,網(wǎng)關(guān)和MAC的方法,涉及javascript正則表達式的相關(guān)使用技巧,需要的朋友可以參考下
    2015-07-07
  • 深入理解JavaScript中的傳值與傳引用

    深入理解JavaScript中的傳值與傳引用

    這篇文章主要是對JavaScript中的傳值與傳引用進行了詳細(xì)的介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2013-12-12

最新評論