您当前的位置:首页 > 网站建设 > ajax
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax | jQuery |

关于ajax网络请求的封装实例

51自学网 2022-02-21 10:53:23
  ajax

实例代码:

// 封装的ajax网络请求函数// obj 是一个对象function AJAX(obj){    //跨域请求    if (obj.dataType == "jsonp") {      //在这里 callback 必须是全局变量 保证函数消失的时候 这个变量不可以被销毁      //处理一下函数名(防止多个网络请求 函数名字相同 出现紊乱的情况)      var hehe = "callBack" + "_" + new Date().getTime() + "_" + String(Math.random()).replace(".","");      window[hehe] = obj.success;      //创建 script标签      var sc = document.createElement("script");      sc.src = obj.url + "?" + "cb=" + hehe;      console.log(sc.src);      document.body.appendChild(sc);      document.body.removeChild(sc);      return;    }  //1、创建 ajax 对象  var ajaxObj = null;  if (window.XMLHttpRequest) {    ajaxObj = new XMLHttpRequest();  }else{    ajaxObj = new ActiveXObject("Microsoft.XMLHTTP");  }  //设置请求的类型  obj.type = obj.type.toUpperCase() || "GET";  //如果是get请求 并且需要传递参数 则需要给 url 后面拼接参数  if (obj.type == "GET") {    var arr = [];//定义数组 用于把对象存储到数据里面    for (var key in obj.data) {      arr.push(key +"="+ obj.data[key]);    }    //用&分隔数组 让其转化为类似:name=lxl&age=18 的形式    var str = arr.join("&");    obj.url = obj.url +"?"+ str;    //拨号    ajaxObj.open(obj.type,obj.url,true);    //发送"name=123&age=18"    ajaxObj.send();  }else{    var arr = [];//定义数组 用于把对象存储到数据里面    for (var key in obj.data) {      arr.push(key +"="+ obj.data[key]);      //console.log(arr);    }    //用&分隔数组 让其转化为类似:name=lxl&age=18 的形式    var str = arr.join("&");    //console.log(str);    ajaxObj.open(obj.type,obj.url,true);    ajaxObj.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");    ajaxObj.send(str);  }  //监听  ajaxObj.onreadystatechange = function(){    if (ajaxObj.readyState == 4) {      if (ajaxObj.status >= 200 && ajaxObj.status < 300 || ajaxObj.status == 304) {        //请求成功        obj.success(ajaxObj.responseText);      }else{        //请求失败        obj.error(ajaxObj.status);      }    }  }}

以上这篇关于ajax网络请求的封装实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持51zixue.net。


下载地址:
原生AJAX封装的简单实现
Ajax+Struts2实现验证码验证功能实例代码
51自学网,即我要自学网,自学EXCEL、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。
京ICP备13026421号-1