Promise封装ajax

XMLHttpRequest

设置请求头类型

typecode
表单字符类型application/x-www-form-urlencoded
表单类型multiline/form-data
json 类型application/json
xhr = new XMLHttpRequest();
xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
复制代码
Promise
  • Promise对象代表一个异步操作,有三种状态:
    • pending 进行中
    • fulfilled 已成功
    • rejected 已失败

对象的状态不受外界影响,一旦状态改变,就不会再变

  • Promise对象的状态改变,只有两种可能:
    • pending => fulfilled
    • pending => rejected
JavaScript封装XMLHttpRequest
function pmiseAjax(type, url, data) {

    return new Promise(function(resolve, reject) {

        var xhr = null
        if (window.XMLHttpRequest) {
            xhr = new XMLHttpRequest();
        } else {
            xhr = new ActiveXObject("Microsoft.XMLHTTP");
        }

        xhr.open(type, url, true);

        xhr.onreadystatechange = function(){
            if (xhr.readyState == 4 && xhr.status == 200) {
                resolve(JSON.parse(xhr.responseText));
            } else {
                reject(xhr)
            }
        }

        if (type == 'GET') {
            xhr.send()
        } else {
            xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded");
            xhr.send(formatParams(data));
        }

    })

    function formatParams(data) {
        var arr = [];
        for(var name in data){
            arr.push(name + '=' + data[name]);
        }
        return arr.join("&");
    }
}
复制代码
jQuery封装$.ajax
function pmiseAjax(options) {
    return new Promise(function(resolve, reject) {
        var $params = $.extend({ type: "GET", url: "", data: {}, global: false, async: true }, options);
        var $callback = callback || "";

    // console.log($params);
    $.ajax({
        type: $params.type,
        url: $params.url,
        async: $params.async,
        data: $params.data,
        dataType: "json",
        contentType: "application/json;charset=utf-8",
        // 触发全局AJAX事件  true:默认值,打开全局事件;false:关闭
        global: $params.global, 
        cache: false,
        success: function(data) {
            resolve(data);
        },
        error: function(err) {
            reject(error);
        },
        beforeSend: function(xhr) {
            if ($.isFunction($params.beforeSend)) {
                $params.beforeSend(xhr);
            }
        },
        complete: function(xhr) {
            // return;
            if ($.isFunction($params.complete)) {
                $params.complete(xhr);
            }
        }
    });
    })
}
复制代码

转载于:https://juejin.im/post/5b6a6a83e51d4517c564e5fc

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值