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 相关文章推荐
用jscript实现列出安装的软件列表
Jun 18 Javascript
jquery 层次选择器siblings与nextAll的区别介绍
Aug 02 Javascript
js之onload事件的一点使用心得
Aug 14 Javascript
AngularJS中处理多个promise的方式
Feb 02 Javascript
基于jquery实现ajax无刷新评论
Aug 19 Javascript
jquery实现页面加载效果
Feb 21 Javascript
深入理解vue-loader如何使用
Jun 06 Javascript
20行JS代码实现网页刮刮乐效果
Jun 23 Javascript
Javascript之图片的延迟加载的实例详解
Jul 24 Javascript
利用js将ajax获取到的后台数据动态加载至网页中的方法
Aug 08 Javascript
JavaScript实现简单随机点名器
Nov 21 Javascript
在vue项目中promise解决回调地狱和并发请求的问题
Nov 09 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
sony ICF-2010 拆解与改装
2021/03/02 无线电
php URL跳转代码 减少外链
2011/06/25 PHP
PHP内核探索之解释器的执行过程
2015/12/22 PHP
PHP错误机制知识汇总
2016/03/24 PHP
YII动态模型(动态表名)支持分析
2016/03/29 PHP
php微信公众账号开发之前五个坑(一)
2016/09/18 PHP
Thinkphp 框架扩展之数据库驱动常用方法小结
2020/04/23 PHP
js中的escape及unescape函数的php实现代码
2007/09/04 Javascript
jquery 全局AJAX事件使用代码
2010/11/05 Javascript
JS冒泡事件的快速解决方法
2013/12/16 Javascript
JQuery的Ajax请求实现局部刷新的简单实例
2014/02/11 Javascript
一个简单的jquery进度条示例
2014/04/28 Javascript
一个可以增加和删除行的table并可编辑表格中内容
2014/06/16 Javascript
JQuery表单验证插件EasyValidator用法分析
2014/11/15 Javascript
使用pjax实现无刷新更改页面url
2015/02/05 Javascript
jQuery实现的简单悬浮层功能完整实例
2017/01/23 Javascript
jQuery实现输入框的放大和缩小功能示例
2018/07/21 jQuery
TypeScript高级用法的知识点汇总
2019/12/17 Javascript
js实现滑动进度条效果
2020/08/21 Javascript
[01:42:49]DOTA2-DPC中国联赛 正赛 iG vs PSG.LGD BO3 第一场 2月26日
2021/03/11 DOTA
python的类方法和静态方法
2014/12/13 Python
Python 基础之字符串string详解及实例
2017/04/01 Python
用Python实现KNN分类算法
2017/12/22 Python
python调用百度REST API实现语音识别
2018/08/30 Python
根据tensor的名字获取变量的值方式
2020/01/04 Python
使用Python求解带约束的最优化问题详解
2020/02/11 Python
基于Python测试程序是否有错误
2020/05/16 Python
Algenist奥杰尼官网:微藻抗衰老护肤品牌
2017/07/15 全球购物
将世界上最美丽的摄影作品转化为艺术作品:Photos.com
2017/11/28 全球购物
Belvilla法国:休闲度假房屋出租
2020/10/03 全球购物
简历自荐信
2013/12/02 职场文书
索桥的故事教学反思
2014/02/06 职场文书
人力资源作业细则
2014/03/03 职场文书
大学共青团员个人自我评价
2014/04/16 职场文书
暑期社会实践新闻稿
2015/07/17 职场文书
Python3.8官网文档之类的基础语法阅读
2021/09/04 Python