时间:2021-05-26
问题:项目中有一个需求,一个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 按顺序请求数据的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在js异步请求数据时,通常,我们多采用回调函数的方式解决,但是,如果有多个回调函数嵌套时,代码显得很不优雅,维护成本也相应较高。ES6提供的Promise方法和
在js里面,偶尔会遇见需要多个异步按照顺序执行请求,又不想多层嵌套,,这里和promise.all的区别在于,promise或者Jquery里面的$.when是
在vue项目中,每次和后台交互的时候,经常用到的就是axios请求数据,它是基于promise的http库,可运行在浏览器端和node.js中。当项目越来越大的
微信小程序es6-promise.js封装请求与处理异步进程下载es6-promise.js置于根目录下的libs文件夹下;在根目录utils文件夹下新建htt
1、vue开发后台管理项目,登录后,请求数据每次session都不一致,后台返回未登录,处理方法打开main.js设置://TheVuebuildversion