最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 21:51:41
文档

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

js利用递归与promise 按顺序请求数据的方法:问题:项目中有一个需求,一个tabBar下面如果没有内容就不让该tabBar显示,当然至于有没有内容,需要我们通过请求的来判断,但是由于请求是异步的,如何让请求按照tabBar的顺序进行? 方案:我们可以将promise变成下一个请求,可以利用递归来实现 实施:
推荐度:
导读js利用递归与promise 按顺序请求数据的方法:问题:项目中有一个需求,一个tabBar下面如果没有内容就不让该tabBar显示,当然至于有没有内容,需要我们通过请求的来判断,但是由于请求是异步的,如何让请求按照tabBar的顺序进行? 方案:我们可以将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 按顺序请求数据的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

文档

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

js利用递归与promise 按顺序请求数据的方法:问题:项目中有一个需求,一个tabBar下面如果没有内容就不让该tabBar显示,当然至于有没有内容,需要我们通过请求的来判断,但是由于请求是异步的,如何让请求按照tabBar的顺序进行? 方案:我们可以将promise变成下一个请求,可以利用递归来实现 实施:
推荐度:
标签: 内容 方法 请求
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top