用Promise实现一个请求超时

用Promise实现一个请求超时

  • 今天面试了一家公司,面试官问了一个‘能不能自己实现一个请求超时’,刚开始还是有点慌的,经过思考有了一些思路
  • 请求请求!!第一时间想到的就是promise
  • 刚好promise有个api是promise.race([api1,api2…]),这个api会优先返回最快的那一个请求
   let rest = function (_data = 4000) {
        return Promise.race([
            upload(),
            Timeout(_data)
        ])
    }
    function upload() {
        console.log('请求进行中...');
        return new Promise((resolve, reject) => {
        	//模拟的接口
            setTimeout(() => {
                resolve({ data:{code:200,data:[]} })
            }, 2000);
            // 向外暴露取消函数
            cancelFn = function (msg) {
                reject('请求超时,请重试');
            }

        })
    };
    function Timeout(times) {
        return new Promise((resolve, reject) => {
            setTimeout(() => {
                cancelFn();
            }, times)
        })
    }
   let res= rest()
    res.then(res=>{
        console.log(res);
    })
  • 还有一个题是手写一个sleep函数
   async function async1(){
       await async2()
       //2秒后返回一个1
       console.log(1);
   }
   function async2(){
      ··········
   }
 async function async1(){
       await async2(2000)
       //2秒后返回一个1
       console.log(1);
   }
   function async2(timeout){
      return new Promise((resolve,reject)=>{
          setTimeout(() => {
            resolve()
          }, timeout);
      })
   }
   async1()
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值