js循环调用异步接口请求

得到一个需求,需要循环调用接口十次,并且每次调用时延迟1s,如果得到结果则结束循环。处理如下:

const getLoopResult = async (index, total, isGetRes) => {
     await new Promise((resolve) => {
         setTimeout(() => {
             getFunctionResult({'b':b}).then(res => {
                 // 调用请求成功
                 if(res.code == 200) {
                   isGetRes = true
                   this.setData({
                       isMute: b,
                       isClickedXiaoyinBtn: false
                   })
                   wx.hideToast()
                 } else {
                     isGetRes = false
                     if(index === total - 1) {
                     // 第十次调用请求失败
                         wx.hideToast({
                           success: () => {
                               wx.showToast({
                                 title: `设备${that.data.isMute == 1 ?'关闭':'打开'}失败,请稍候再试`,
                                 icon: 'none'
                               })
                           },
                         })
                         that.setData({
                           isClickedXiaoyinBtn: false
                         })
 
                     }
                 }
                 resolve(isGetRes)
             })
         }, 1000)

     })
     if(index < total-1 && !isGetRes) {
         getLoopResult(index+1, total, isGetRes)
     }
    
}

// 最多调用getFunctionResult十次,并且每次延迟1s再调用接口
getLoopResult (0, 10, false)


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript 中,可以使用 Promise 的循环调用来处理需要重复请求接口的情况。通过递归地调用 Promise,可以实现连续发送请求直到满足特定条件为止。 下面是一个使用 Promise 循环调用请求接口的示例: ```javascript // 模拟发送请求的函数 function sendRequest(url) { return new Promise((resolve, reject) => { // 发送异步请求 // 假设这里使用 AJAX 或者 fetch 等方法发送请求 // 这里使用 setTimeout 模拟异步请求返回结果 setTimeout(() => { // 假设请求成功的情况 const response = { success: true, data: 'Some data' }; resolve(response); // 假设请求失败的情况 // reject(new Error('Request failed')); }, 1000); }); } // 循环调用请求接口 function loopRequests(url, condition) { return sendRequest(url).then(response => { // 处理接口返回的结果 console.log(response); // 检查是否满足终止条件 if (condition(response)) { return response; } else { // 继续循环调用请求接口 return loopRequests(url, condition); } }); } // 示例使用 const url = 'https://api.example.com/data'; const condition = response => response.success && response.data.length < 10; loopRequests(url, condition) .then(finalResponse => { console.log('Final response:', finalResponse); }) .catch(error => { console.error('An error occurred:', error); }); ``` 在这个示例中,`sendRequest` 函数模拟了一个发送请求异步操作,并返回一个 Promise。在实际应用中,你可以使用 AJAX、fetch 或其他方法来发送实际的请求。 `loopRequests` 函数接收一个 URL 和一个条件函数作为参数。它首先发送一个请求,然后根据条件函数判断是否满足终止条件。如果满足终止条件,函数将返回最终的响应结果;否则,它将递归地调用 `loopRequests` 函数来继续发送请求,直到满足终止条件为止。 在示例中,我们定义了一个条件函数 `condition`,它检查接口返回的结果是否成功且数据长度小于 10。如果满足这个条件,循环调用将停止,并打印最终的响应结果。 请注意,在实际的应用中,你需要根据具体情况来定义终止条件和处理请求结果的逻辑。此外,还应该小心处理错误和异常情况,以确保代码的稳定性和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值