茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

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

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

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

    下面是對一個基本的 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 © 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 。

    更多信息請查看網(wǎng)絡(luò)編程
    易賢網(wǎng)手機網(wǎng)站地址:實例講解使用原生JavaScript處理AJAX請求的方法

    2026上岸·考公考編培訓(xùn)報班

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