中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

實例講解使用原生JavaScript處理AJAX請求的方法
來源:易賢網 閱讀:1029 次 日期:2016-07-01 14:46:37
溫馨提示:易賢網小編為您整理了“實例講解使用原生JavaScript處理AJAX請求的方法”,方便廣大網友查閱!

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

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

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

var xhr = new XMLHttpRequest();

xhr.open('GET', 'send-ajax-data.php');

xhr.send(null);

在這里, 我們創建了一個能向服務器發出 HTTP 請求的類的實例。然后調用其 open 方法,其中第一個參數是 HTTP 請求方法,第二個參數是請求頁面的 URL。最后,我們調用參數為 null 的 send 方法。假如使用 POST 請求方法(這里我們使用了 GET),那么 send 方法 的參數應該包含任何你想發送的數據。

下面是我們如何處理服務器的響應:

xhr.onreadystatechange = function(){

 var DONE = 4; // readyState 4 代表已向服務器發送請求

 var OK = 200; // status 200 代表服務器返回成功

 if(xhr.readyState === DONE){

  if(xhr.status === OK){

   console.log(xhr.responseText); // 這是返回的文本

  } else{

   console.log("Error: "+ xhr.status); // 在此次請求中發生的錯誤

  }

 }

}

onreadystatechange 是異步的,那么這就意味著它將可在任何時候被調用。這種類型的函數被稱為回調函數——一旦某些處理完成后,它就會被調用。在此案例中,這個處理發生在服務器。

示例

便捷的 Ajax 方法也是不少人依賴 jQuery 的原因,但實際上原生 JavaScript 的 Ajax api 也很強大,并且基本的使用在各個瀏覽器中的差異不大,因此完全可以自行封裝一個 Ajax 對象,下面是封裝好的 Ajax 對象:

// Ajax 方法

// 惰性載入創建 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 執行

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' ){

     // 獲取服務器返回的 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);

   }

  }

 };

 // 設置請求參數

 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 實現 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 © 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 獲取內容</a>

  <div id="test"></div>

 </div>

 <script>

  // Ajax 方法,這里不在重復列出

 </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 。

更多信息請查看網絡編程
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
欧美精品自拍偷拍动漫精品| 亚洲精品欧美激情| 欧美一区二区三区成人 | 国内激情久久| 国产精品一区免费观看| 欧美激情一区二区| 欧美一区国产二区| 一本色道久久综合精品竹菊 | 老鸭窝毛片一区二区三区| 久久成人亚洲| 欧美伊人久久久久久午夜久久久久 | 亚洲激情午夜| 亚洲国产日韩精品| 亚洲国产女人aaa毛片在线| 国产精品卡一卡二| 欧美日韩一区二区三区| 国产精品久久久久一区二区| 国产精品99一区| 国产女人18毛片水18精品| 国产精品美女黄网| 国产伦精品一区二区三区视频黑人 | 国产精品免费一区豆花| 1769国内精品视频在线播放| 亚洲国产裸拍裸体视频在线观看乱了中文| 亚洲国产视频直播| 亚洲欧美大片| 免费亚洲视频| 国产真实久久| 亚洲视频网站在线观看| 欧美一区高清| 欧美日韩在线观看一区二区| 国产欧美日韩麻豆91| 国产欧美日韩综合一区在线播放| 亚洲国产精品va在线看黑人| 亚洲一区二区免费看| 欧美国产一区视频在线观看| 欧美手机在线| 欧美在线视频免费观看| 国产日韩欧美综合精品| 在线视频精品一| 老色鬼久久亚洲一区二区| 欧美久久一区| 亚洲一区二区综合| 国产精品国产福利国产秒拍| 亚洲黄色有码视频| 久久免费视频在线| 影音先锋欧美精品| 久久久久久夜精品精品免费| 1024精品一区二区三区| 久久亚洲高清| 国产一区在线视频| 亚洲免费影视| 国产一区二区三区久久悠悠色av| 亚洲欧美日韩视频一区| 欧美视频你懂的| 91久久线看在观草草青青| 欧美一二三区精品| 欧美三级网址| 亚洲精品乱码久久久久| 久久久一区二区三区| 狠狠狠色丁香婷婷综合久久五月 | 国产精品免费网站| 亚洲精品乱码| 欧美视频一区二区三区在线观看| 一本大道久久精品懂色aⅴ | 一卡二卡3卡四卡高清精品视频| 欧美成熟视频| 性感少妇一区| 在线日韩中文字幕| 国产精品高清免费在线观看| 午夜精品福利在线| 一本久道久久综合狠狠爱| 国产欧美日韩综合一区在线观看| 久久精品国产一区二区三区 | 西瓜成人精品人成网站| 国产综合久久| 欧美日韩系列| 欧美精品成人91久久久久久久| 久久一区二区三区av| 亚洲欧美激情四射在线日| 亚洲第一精品在线| 国产欧美三级| 欧美日韩国产精品专区| 久久久精品网| 免费在线看成人av| 久久综合一区二区三区| 久久婷婷综合激情| 久久成人免费| 葵司免费一区二区三区四区五区| 欧美一级在线亚洲天堂| 亚洲破处大片| 亚洲三级性片| 亚洲精品国产视频| 欧美影院精品一区| 久久国产精品一区二区三区| 欧美一区日本一区韩国一区| 亚洲亚洲精品在线观看| 蜜桃av一区二区| 久久天天狠狠| 男女精品网站| 国产精品激情av在线播放| 好看的日韩视频| 在线观看一区视频| 在线免费观看日本欧美| 精品福利免费观看| 亚洲一区二区影院| 欧美一区二区三区四区在线| 久久综合狠狠| 国产亚洲精品高潮| 亚洲黄色高清| 久久精品女人的天堂av| 欧美电影资源| 国产香蕉97碰碰久久人人| 国语自产精品视频在线看| 精久久久久久久久久久| 国产精品亚洲美女av网站| 国内一区二区三区在线视频| 日韩视频在线永久播放| 欧美日韩高清在线一区| 亚洲第一综合天堂另类专| 午夜在线电影亚洲一区| 国产精品日韩欧美大师| 亚洲婷婷在线| 国产麻豆视频精品| 久久精品电影| 在线不卡中文字幕| 欧美电影在线观看完整版| 亚洲高清久久网| 欧美精品少妇一区二区三区| 一区二区精品| 国产欧美日韩一级| 乱中年女人伦av一区二区| 亚洲三级免费| 国产午夜精品麻豆| 欧美国产一区二区| 一区二区三区黄色| 国产日韩专区| 欧美日韩一区在线观看| 久久riav二区三区| 亚洲美女在线一区| 韩国一区二区三区在线观看| 欧美极品在线播放| 久久国产免费| 一二三四社区欧美黄| 在线观看欧美亚洲| 国产日韩欧美不卡| 国产精品成av人在线视午夜片| 久久国产精品第一页| 亚洲一级二级| 一本久久综合| 日韩视频亚洲视频| 亚洲第一在线综合在线| 韩国三级电影久久久久久| 欧美人与性动交a欧美精品| 噜噜噜噜噜久久久久久91| 美国三级日本三级久久99| 欧美精品在线免费播放| 国产精品久久久一本精品| 国产尤物精品| 国产视频亚洲精品| 亚洲国产成人久久| 亚洲一区视频在线| 欧美中在线观看| 欧美日韩国产在线| 乱中年女人伦av一区二区| 久久综合色播五月| 欧美日韩免费一区二区三区视频| 欧美国产欧美亚洲国产日韩mv天天看完整 | 久久精品99| 久久精品一级爱片| 欧美风情在线| 国内精品久久久| 国产在线成人| 欧美日韩免费高清一区色橹橹| 国内精品一区二区| 亚洲综合大片69999| 国产免费一区二区三区香蕉精| 欧美一区三区二区在线观看| 国产精品国产三级国产普通话蜜臀| 国产视频在线一区二区| 久久er精品视频| 亚洲高清毛片| 国产日韩欧美一区二区三区四区| 欧美暴力喷水在线| 午夜精品短视频| 一区二区日韩欧美| 欧美在线播放| 亚洲无限av看| 亚洲性视频网址| 久久久久天天天天| 欧美日本一区二区高清播放视频| 欧美日韩一区二区在线观看视频| 国产欧美日本| 亚洲一区国产| 欧美日韩三级一区二区| 亚洲国产精品一区二区三区| 久久精品国产亚洲5555| 国产精品亚洲综合久久| 亚洲自拍16p| 国产精品久久久久久久久借妻|