js封装ajax方法

来源:互联网 发布:seo公司哪家专业 编辑:程序博客网 时间:2024/05/17 22:50

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