js循环调用接口

12 篇文章 0 订阅

一、使用场景

当前端调用后端接口时,如果被调用的接口有数量限制,比如一个获取人员列表的接口,接口限制每次最多获取1000条数据,而人员总数有2000多条,此时我们需要循环调用接口,从而获取到所有的人员列表。

二、方法

注:以下示例代码是在vue中的写法

  • 第一步:封装被循环调用的接口
async getList(url,method,data){
     return axios({
        method: method,//请求方式,get/post
        url: url,//接口路径
        data: data//请求参数
      })
        .then((res) => {
          if (res.data.success==true) {
            return res.data  
          } 
        })
        .catch((err) => {
          console.log("获取数据失败",err)
        });
    }
  • 第二步:循环调用封装好的getList()函数,获取所有数据
//由于调用getList()时,用到了await,所以方法前面需要加上async
async requestData() {
let url = "/api/v2/open/worksheet/getFilterRows";
let method="post";
let data = {
      pageSize: 1000,
      pageIndex: 1
    }   
let content=[];//存放多次调用获取到的数据
//获取第一页数据
var results=await this.getList(url,method,data);
//将第一页数据放入content数组中
content=content.concat(results.list);

//如果数据超过1000条,获取第2、3、4...页数据
var total = results.total;//获取总条数
var page = Math.ceil(total/1000);//计算需要多少页
if(page>1){
 for(var i = 2;i<=page;i++){
   data.pageIndex = i;//更改页码
   let newResults = await this.getList(url,method,data);
   //将第2、3、4...页数据放入content数组中
   content=content.concat(newResults.list);
}
}
  • 第三步:在created中调用requestData()函数
 created() {
    this.requestData();
 }
  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值