• 实例讲解使用原生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;  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 { 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 href="http://kayosite.com/css3-animation.html" title="打开原文" target="_blank" >Back To Article</a></p>
        <p class="go-to-blog"><a href="http://kayosite.com" 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 。

  • 相关阅读:
    根据CPU核数合理设置线程池大小
    jvm类加载的过程
    springboot2.x整合redis实现缓存(附github链接)
    记录一次坎坷的debug之旅,NUXT框架页面多开假死现象,NUXT刚开始可以访问,突然就访问无响应,并且前后端均未出现任何报错提示:现在是早晨4点35分
    hibernate用Query.setFirstResult和Query.setMaxResults分页时,传入的manresults不能为0,否则解析后的sql会去查全表数据
    工作时发现oracle的分页查询的数据会重复,进行分析并给出解决方式
    看别人的代码是进步最快的方式
    关于电磁炉使用时造成的电磁场导致洗衣机等电器失效的情况总结
    关于在项目中创建一个新的线程之后需要将线程持有的数据库连接对象归还的思考
    Oracle分页和mysql分页的区别
  • 原文地址:https://www.cnblogs.com/sanshao221/p/6530098.html
Copyright © 2020-2023  润新知