實(shí)例講解使用原生JavaScript處理AJAX請(qǐng)求的方法
來(lái)源:易賢網(wǎng) 閱讀:785 次 日期:2016-07-01 14:46:37
溫馨提示:易賢網(wǎng)小編為您整理了“實(shí)例講解使用原生JavaScript處理AJAX請(qǐng)求的方法”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹了實(shí)例講解使用原生JavaScript處理AJAX請(qǐng)求的方法,這樣就算是利用原生API而脫離了jQuery中的Ajax方法,需要的朋友可以參考下

Ajax 是異步的JavaScript和XML的簡(jiǎn)稱(chēng),是一種更新頁(yè)面某部分的機(jī)制。它賦予了你從服務(wù)器獲取數(shù)據(jù)后,更新頁(yè)面某部分的權(quán)力,從而避免了刷新整個(gè)頁(yè)面。另外,以此方式實(shí)現(xiàn)頁(yè)面局部更新,不僅能有效地打造流暢的用戶(hù)體驗(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)求的類(lèi)的實(shí)例。然后調(diào)用其 open 方法,其中第一個(gè)參數(shù)是 HTTP 請(qǐng)求方法,第二個(gè)參數(shù)是請(qǐng)求頁(yè)面的 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)用。這種類(lèi)型的函數(shù)被稱(chēng)為回調(diào)函數(shù)——一旦某些處理完成后,它就會(huì)被調(diào)用。在此案例中,這個(gè)處理發(fā)生在服務(wù)器。

示例

便捷的 Ajax 方法也是不少人依賴(lài) 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();

 // 通過(guò)事件來(lái)處理異步請(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="打開(kāi)原文" 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>

ajax.html:

<!DOCTYPE HTML>

<html lang="zh-CN">

<head>

 <meta charset="UTF-8">

 <title>ajax</title>

</head>

<body>

 <p>成功獲取到這段文本</p>

</body>

</html>

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

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:實(shí)例講解使用原生JavaScript處理AJAX請(qǐng)求的方法
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢(xún)回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢(xún)?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類(lèi)型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢(xún) | 簡(jiǎn)要咨詢(xún)須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專(zhuān)用圖標(biāo)
聯(lián)系電話(huà):0871-65099533/13759567129 獲取招聘考試信息及咨詢(xún)關(guān)注公眾號(hào):hfpxwx
咨詢(xún)QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)