原生js封装ajax案例-创新互联

有时候在做开发的时候,会用到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) {
           //执行失败的代码
        }
    });

}

创新互联www.cdcxhl.cn,专业提供香港、美国云服务器,动态BGP最优骨干路由自动选择,持续稳定高效的网络助力业务部署。公司持有工信部办法的idc、isp许可证, 机房独有T级流量清洗系统配攻击溯源,准确进行流量调度,确保服务器高可用性。佳节活动现已开启,新人活动云服务器买多久送多久。


网站名称:原生js封装ajax案例-创新互联
转载来于:http://pwwzsj.com/article/dddhgh.html