实例讲解使用原生JavaScript处理AJAX请求的方法
来源: 阅读:749 次 日期: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 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 。

更多信息请查看网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map