博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
原生JavaScript封装的ajax方法示例
阅读量:6080 次
发布时间:2019-06-20

本文共 1783 字,大约阅读时间需要 5 分钟。

hot3.png

众所周知,框架之间会有冲突,这是源生js就起到作用了,下面介绍一种源生js封装的ajax请求。

function ajax(options) {  options = options || {};  options.type = (options.type || "GET").toUpperCase();  options.dataType = options.dataType || "json";  var params = formatParams(options.data);  //创建xhr对象 - 非IE6  if (window.XMLHttpRequest) {    var xhr = new XMLHttpRequest();  } else { //IE6及其以下版本浏览器    var xhr = new ActiveXObject('Microsoft.XMLHTTP');  }  //GET POST 两种请求方式  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");    xhr.send(params);  }  //接收  xhr.onreadystatechange = function () {    if (xhr.readyState == 4) {      var status = xhr.status;      if (status >= 200 && status < 300) {        options.success && options.success(xhr.responseText);      } else {        options.fail && options.fail(status);      }    }  }}//格式化参数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("&");}

调用方法

ajax({  url: "data.json",  type: "GET",  data: {},  dataType: "json",  success: function (response) {    // 此处放成功后执行的代码     // 解析返回的字符串 转为json对象    var usingdata = eval("("+response+")").data;  }  fail: function (status) {    // 此处放失败后执行的代码  }});

最后

为了帮助大家让学习变得轻松、高效,给大家免费分享一大批资料,帮助大家在成为全栈工程师,乃至架构师的路上披荆斩棘。在这里给大家推荐一个前端全栈学习交流圈:.欢迎大家进群交流讨论,学习交流,共同进步。

当真正开始学习的时候难免不知道从哪入手,导致效率低下影响继续学习的信心。

但最重要的是不知道哪些技术需要重点掌握,学习时频繁踩坑,最终浪费大量时间,所以有有效资源还是很有必要的。

最后祝福所有遇到瓶疾且不知道怎么办的前端程序员们,祝福大家在往后的工作与面试中一切顺利。

转载于:https://my.oschina.net/u/3970421/blog/2995636

你可能感兴趣的文章
zookeeper安装与配置
查看>>
redis和memcached区别
查看>>
c primer plus(第五版)读书笔计 第七章(6)
查看>>
PHP缓存技术
查看>>
kubernetes集成calico网络
查看>>
RabbitMQ - Throuble Shooting
查看>>
python 的hmac与php的hash_hmac的签名校验
查看>>
2015年11月 广州深圳 MVP 线下活动
查看>>
微软私有云分享(R2)24 审核WDS部署
查看>>
centos 6和centos 7的有哪些区别?
查看>>
我的友情链接
查看>>
SSH
查看>>
Kbengine版炉石传说教程-序章-源代码获取
查看>>
js Unicode编码相互转换
查看>>
linux文件合并
查看>>
SCCM 2012 与Windows 2003
查看>>
Mysql数据库理论基础之九---四类隔离级别
查看>>
HTML5预测 取代本地App将成为可能
查看>>
nginx日志切割脚本
查看>>
Linux下(.vimrc文件)
查看>>