首页 > 开发 > AJAX > 正文

原生js封装的ajax方法示例

2024-09-01 08:33:58
字体:
来源:转载
供稿:网友

本文实例讲述了原生js封装的ajax方法。分享给大家供大家参考,具体如下:

众所周知,框架之间会有冲突,这是源生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) {    // 此处放失败后执行的代码  }});

希望本文所述对大家JavaScript程序设计有所帮助。


注:相关教程知识阅读请移步到JavaScript/Ajax教程频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表