最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 实现axios限制请求队列

    正文概述 掘金(Tzyito)   2021-07-23   464

    在实际开发中,可能会遇到网络问题或者查询量比较大的情况,上一个请求还没有完成,用户就发起了下一个请求。

    但是同一个请求多次发送到服务器,无疑是对服务器的一种压力,所以需要在已经优化服务器过查询速度后,以及用户网络情况比较差的条件下,在前端进行请求限制。

    axios 自带的cancelToken可以帮我们实现这个需求,并且提供给了我们一个现成的api axios.CancelToken ,这是一个返回值是带有请求信息的回调函数,我们可以在需要cancel的时候去执行这个回调函数。具体实现如下:

    const service = axios.create({});
    const penddingMap = new Map();
    const addPendding = (config) => {
    	config.cancelToken = config.cancelToken || new axios.CancelToken(cancel => {
    		if(!penddingMap.has(config.url)){
    			penddingMap.set(config.url,cancel);
    		}
    	})
    }
    
    const removePendding = (config) => {
    	if(penddingMap.has(config.url)){
    		let cancel = penddingMap.get(config.url);
        cancel(config.url);
        penddingMap.delete(config.url)
    	}
    }
    

    本地维护一个Map来存储每个请求信息, addPendding 中每次会去先判断是否有cancelToken,如果有就不用重新创建一个cancelToken。 removePendding 中判断请求信息是否在Map中,如果该请求存在于Map中,则执行cancel函数,并删除Map中的该请求。

    拦截器中的具体应用:

    service.interceptors.request.use(config => {
    	removePending(config) // 如果存在Map中先cancel该请求
      addPendding(config)  // 添加该请求到Map中
      return config
    })
    
    service.interceptors.response.use(response => {
    	``` // some code
      return response.data
    },error => {
    	// 捕获cancel请求并抛出
      if(error instanceof Cancel){
        error.message = '上一请求尚未结束,稍等~';
        Message.error(error.message);
        return Promise.reject(error.response) 
    		// 这里抛出需要注意,在请求时调用try-catch进行捕获
      })
    )
    

    这里拦截成功后,就可以限制住大流量的多次请求。

    如果有补充或者错误的,请不吝指点~


    起源地下载网 » 实现axios限制请求队列

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元