原生javascript封装ajax,promise封装ajax

封装分为三部分,

首先封装状态码,url,type,data,datatype,async,success获取成功的后台数据,error获取失败的状态码

然后封装一个小方法,把调用时输入的对象格式的data转换为url格式的数据,例name=lily&age=20

然后封装xmlhttprequest对象

function myAjax(options) {
    var url = options.url;
    var type = "GET" || options.type.toUpperCase();
    var data = Boj(options.data) || {};
    var dataType = options.dataType;
    var async = options.async || true;

    function Boj(data) {
        var arr = [];
        for (var i in data) {
            arr.push(i + "=" + data[i])
        }
        return arr.join("&")
    }
    var xmlhttp;
    if (window.XMLHttpRequest) {
        xmlhttp = new XMLHttpRequest();
    } else {
        xmlhttp = new ActiveXObject("microsoft.XMLHTTP");
    }
    if (type == "GET") {
        xmlhttp.open('GET', url + "?" + data, async);
        xmlhttp.send();
    } else {
        xmlhttp.open('POST', url, async);
        xmlhttp.setRequestHeader('content-type', 'application/x-www-form-urlencoded');
        xmlhttp.send(data);
    }
    xmlhttp.onreadystatechange = function() {
        if (xmlhttp.readyState == 4) {
            if (xmlhttp.status == 200) {
                options.success(JSON.parse(xmlhttp.responseText))
            } else {
                options.error(xmlhttp.status)
            }
        }
    }
}

使用promise封装ajax、

 //promise封装ajax
        function ajax(type, url, async) {
            return new Promise((resolve, reject) => {
                // 创建Ajax对象
                let xml = new XMLHttpRequest();
                // 设置提交方式
                xml.open(type, url, async)
                    // 设置头部信心
                xml.setRequestHeader('content-type', "appliction/x-www-form-urlencoded");
                // 发送
                xml.send();
                // 响应处理函数
                xml.onreadystatechange = function() {
                    if (xml.readystate == 4) {
                        if (xml.status == 200) {
                            resolve(xml.responseText);
                        } else {
                            reject(new Error(xml.status))
                        }
                    }
                }
            })
        }
        ajax('get', "test.json", true).then(res => {
            console.log(res)
        }).catch(value => {
            console.log(value);
        })

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值