栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

js利用递归与promise 按顺序请求数据的方法

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

js利用递归与promise 按顺序请求数据的方法

问题:项目中有一个需求,一个tabBar下面如果没有内容就不让该tabBar显示,当然至于有没有内容,需要我们通过请求的来判断,但是由于请求是异步的,如何让请求按照tabBar的顺序进行?

方案:我们可以将promise变成下一个请求,可以利用递归来实现

实施:

//定义初始数据 requestlist就像tabBar列表

  let requestlist = [1, 2, 3, 4, 5, 6, 7,8,9];
  //每个tabBar的返回数据使用reslist装起来
  let reslist = [];
  function startapi() {
    //定义counts,用来收集请求的次数,(也可以用reslist的length进行判断)
    let counts = 0;
    return function apirequest() {
 let arg =arguments[0]
 let a = new Promise((res, rej) => {
   //setTimeout模拟请求到接收的时间需要5秒钟
   setTimeout(function () {
     res('成功返回数据');
   },100)
 })
 //无论成功或者失败都要进行下一次,以免阻塞,成功请求的末尾有s标志,失败的末尾有f标志
 a.then(() => {
  counts++;
   if (counts > requestlist.length) {
     return;
   }
   console.log(counts)
   //1,假设当前请求出错的时候我们认为这不合法,假设此时counts为3
   if(counts==3){
   throw new Error('第三个失败')
   }
   //2,假设当前请求下没有数据的时候我们认为不合法 ,假设此时counts为4
   if(counts==4){
    reslist.push(arg + 'f');
   }
   if(counts!=4){
   reslist.push(arg + 's');
   }
   apirequest(requestlist[counts])
   console.log(reslist)
 }).catch(err => {
 reslist.push(arg + 'f');
 //递归调用
 apirequest(requestlist[counts])
   console.log(err)
 })
    }
  }
  let newapiget = startapi();
  newapiget(requestlist[0])

 最终我们打印结果得到:

 

 可以看到第三个和第四个结尾为f

总结

以上所述是小编给大家介绍的js利用递归与promise 按顺序请求数据的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对考高分网网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/74019.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号