带请求超时的fetch插件

项目中使用的fetch插件没有设置请求超时的属性,在部分场景中需要使用到请求超时提醒,考虑在fetch的基础上编写一个带请求超时的插件

本身fetch是根据promise开发的,考虑使用promise中的race配合settimeout来实现这个需求,下面贴上插件代码

(function (self) {
    "use strict";

    //默认的超时时间
    var options={
        timeout:20000
    };

    self.sqfetch=function(url,init,opts){
        if(opts) {
            for (var key in opts) {
                options[key] = opts[key];
            }
        }
        var fetchPromise=fetch(url, init);
        var timeoutPromise=new Promise(function(resolve, reject){
            setTimeout(function(){
                reject("timeout");
            },options.timeout);
        });
        return Promise.race([fetchPromise, timeoutPromise]);
    };
})(typeof self !== 'undefined' ? self : this);

使用时直接使用sqfetch(url,opts,timeout)即可,opts为fetch中相关的请求参数,timeout为自定义的options,如:

sqfetch(url,{headers:{'Authorization':token},method:'get'},{timeout:5000}).then(function(res) {
    ...
}).catch(function () {
    ...
})

 

传送门:

1. Promise文档:Promise - JavaScript | MDN

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值