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


Posted in Javascript onAugust 30, 2019

问题:项目中有一个需求,一个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])

 最终我们打印结果得到:

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

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

总结

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

Javascript 相关文章推荐
GWT中复制到剪贴板 js+flash实现复制 兼容性比较好
Mar 07 Javascript
小议Javascript中的this指针
Mar 18 Javascript
javascript 3d 逐侦产品展示(核心精简)
Mar 26 Javascript
JavaScript中this的9种应用场景及三种复合应用场景
Sep 12 Javascript
学习使用bootstrap的modal和carousel
Dec 09 Javascript
详解vue2路由vue-router配置(懒加载)
Apr 08 Javascript
Vue 兄弟组件通信的方法(不使用Vuex)
Oct 26 Javascript
微信小程序如何获取用户手机号
Jan 26 Javascript
微信小程序商品详情页的底部弹出框效果
Nov 16 Javascript
jquery添加div实现消息聊天框
Feb 08 jQuery
JavaScript基于SVG的图片切换效果实例代码
Dec 15 Javascript
js面向对象编程OOP及函数式编程FP区别
Jul 07 Javascript
Vue-CLI 项目在pycharm中配置方法
Aug 30 #Javascript
JS实现页面跳转与刷新的方法汇总
Aug 30 #Javascript
Vue 动态组件components和v-once指令的实现
Aug 30 #Javascript
java实现单链表增删改查的实例代码详解
Aug 30 #Javascript
vuex vue简单使用知识点总结
Aug 29 #Javascript
js中的this的指向问题详解
Aug 29 #Javascript
Node4-5静态资源服务器实战以及优化压缩文件实例内容
Aug 29 #Javascript
You might like
php中判断数组是一维,二维,还是多维的解决方法
2013/05/04 PHP
解析php常用image图像函数集
2013/06/24 PHP
php中的Base62类(适用于数值转字符串)
2013/08/12 PHP
php 常用的系统函数
2017/02/07 PHP
php判断电子邮件是否正确方法
2018/12/04 PHP
javascript 动态设置已知select的option的value值的代码
2009/12/16 Javascript
js 通过html()及text()方法获取并设置p标签的显示值
2014/05/14 Javascript
jQuery中复合属性选择器用法实例
2014/12/31 Javascript
js获取微信版本号的方法
2015/05/12 Javascript
Backbone.js的一些使用技巧
2015/07/01 Javascript
JS实现的3des+base64加密解密算法完整示例
2018/05/18 Javascript
JavaScript对象的特性与实践应用深入详解
2018/12/30 Javascript
详解用Webpack与Babel配置ES6开发环境
2019/03/12 Javascript
vue-quill-editor的使用及个性化定制操作
2020/08/04 Javascript
react+antd 递归实现树状目录操作
2020/11/02 Javascript
JavaScript实现京东快递单号查询
2020/11/30 Javascript
[05:31]DOTA2英雄梦之声_第08期_莉娜
2014/06/23 DOTA
[01:10:57]Liquid vs OG 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
[01:11:02]Secret vs Newbee 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
python标准日志模块logging的使用方法
2013/11/01 Python
在Python的Django框架中加载模版的方法
2015/07/16 Python
python PyTorch参数初始化和Finetune
2018/02/11 Python
修改默认的pip版本为对应python2.7的方法
2018/11/06 Python
浅谈Python 列表字典赋值的陷阱
2019/01/20 Python
python实现字符串加密成纯数字
2019/03/19 Python
Python中如何导入类示例详解
2019/04/17 Python
利用python实现PSO算法优化二元函数
2019/11/13 Python
在python中修改.properties文件的操作
2020/04/08 Python
澳大利亚领先的皮肤诊所:Skin Matrix(抗衰老、痤疮专家、药妆护肤)
2018/05/20 全球购物
平面网站制作专科生的自我评价分享
2013/12/11 职场文书
科研课题实施方案
2014/03/18 职场文书
餐饮商业计划书范文
2014/04/29 职场文书
社区领导班子四风问题原因分析及整改措施
2014/09/28 职场文书
优秀团员自我评价
2015/03/10 职场文书
护理专业自我评价
2015/03/11 职场文书
2016年“六一儿童节”校园广播稿
2015/12/17 职场文书