温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

原生js封装ajax 案例

发布时间:2020-07-12 16:36:18 来源:网络 阅读:936 作者:Percy丶 栏目:开发技术

有时候在做开发的时候,会用到js但是做的页面却不能引用jQuery,担心会和别的jQuery版本冲突。所以就自己封装一个原生的ajax来使用 。

function ajax(options) {         options = options || {};         options.type = (options.type || "GET").toUpperCase();         options.dataType = options.dataType || "json";         var params = formatParams(options.data);         //创建 - 非IE6 - 第一步         if (window.XMLHttpRequest) {             var xhr = new XMLHttpRequest();         } else { //IE6及其以下版本浏览器             var xhr = new ActiveXObject('Microsoft.XMLHTTP');         }         //接收 - 第三步         xhr.onreadystatechange = function () {             if (xhr.readyState == 4) {                 var status = xhr.status;                 if (status >= 200 && status < 300) {                     options.success && options.success(xhr.responseText, xhr.responseXML);                 } else {                     options.fail && options.fail(status);                 }             }         }         //连接 和 发送 - 第二步         if (options.type == "GET") {             xhr.open("GET", options.url + "?" + params, true);             xhr.send(null);         } else if (options.type == "POST") {             xhr.open("POST", options.url, true);                      //设置表单提交时的内容类型             xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded; charset=utf-8");             xhr.send(params);//==============================         }     }     //格式化参数     function formatParams(data) {         var arr = [];         for (var name in data) {             arr.push(encodeURIComponent(name) + "=" + encodeURIComponent(data[name]));         }         arr.push(("v=" + Math.random()).replace(".",""));         return arr.join("&");     }

在js里使用的调用

function findService() {       ajax({         url: "xxxxxxx",  //请求地址         type: "POST",    //请求方式         dataType: "json",    //数据格式         success: function (response) {         var array = eval(response);               //执行成功的代码         },         fail: function (status) {            //执行失败的代码         }     }); }


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI