原生JS封装AJAX

今天咱们来讲说利用原生JS封装AJAX.php

jquery框架的AJAX方法确实很好用,但有时候咱们写的页面须要引入多个JS插件,不必定哪一个插件就会和jquery发生冲突,致使jquery用不了了.或者页面比较简单,不须要加剧浏览器的负担,这时咱们本身封装一个AJAX就是一个很好的办法.jquery

//将数据转换成 a=1&b=2格式;
function json2url(json){
   var arr = [];
   //加随机数防止缓存;
   json.t = Math.random();
   for(var name in json){
      arr.push(name+'='+json[name]);
   }
   return arr.join('&');
}ajax

function ajax(json){
   //1.建立一个ajax对象;
   if(window.XMLHttpRequest){
      var oAjax = new XMLHttpRequest();
   }else{
      var oAjax = new ActiveXObject('Microsoft.XMLHTTP');
   }json

   //考虑默认值:
   if(!json.url){
      alert('请输入合理的请求地址!');
      return;
   }
   json.type = json.type || 'get';
   json.time = json.time || 5000;
   json.data = json.data || {};浏览器

   //判断用户传递的是get仍是post请求:
   switch (json.type.toLowerCase()){
      case 'get':
         //2.打开请求;
         oAjax.open('get',json.url+'?'+json2url(json.data),true);
         //3.发送数据:
         oAjax.send();
         break;
      case 'post':
         //打开请求;
         oAjax.open('post',json.url,true);
         //设置请求头;
         oAjax.setRequestHeader('Content-type','application/x-www-form-urlencoded');
         //发送数据;
         oAjax.send(json2url(json.data));
   }
   //4.获取响应数据
   oAjax.onreadystatechange = function() {
      if (oAjax.readyState == 4) {
         if (oAjax.status >= 200 && oAjax.status < 300 || oAjax.status == 304) {
            //若是外边传递了成功的回调函数,那么就执行,
            json.success && json.success(oAjax.responseText);
         } else {
            //若是外边传递了失败的回调函数,那么就执行,
            json.error && json.error(oAjax.status);
         }
         clearTimeout(timer);//规定时间内取到数据后清除定时器;
      }
   };
   var timer;
   timer = setTimeout(function(){//设置网络响应超时;
      alert('网络响应超时,请稍后再试');
      oAjax.onreadystatechange = null;//网络超时后清除事件;
   },json.time);
};缓存

实际的运用:网络

 <script src="ajax3.js"></script>
    <script>
        window.onload = function(){
            var oBtn = document.getElementById('btn');app

            oBtn.onclick = function(){
                ajax({
                    url:'post.php',
                    data:{
                        a:1,
                        b:2
                    },
                    type:'post',
                    success:function(res){
                        alert(res);
                    },
                    error:function(s){
                        alert(s);
                    }
                });
            }
        }
    </script>框架

但愿对你有帮助,咱们明天见!dom

 

 

坚持!坚持!坚持!坚持!坚持!坚持!

相关文章
相关标签/搜索