首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用for循环进行useFetch?

如何使用for循环进行useFetch?
EN

Stack Overflow用户
提问于 2021-11-26 06:02:34
回答 1查看 272关注 0票数 5

我正在创建一个使用react的应用程序。我得去取几个数据。这是我的fetch语句:

代码语言:javascript
复制
const [periods] = useFetch('/company/' + slug + '/waterfall?colIndexOffset=6 ');

在行的末尾,它是一个6,但是我遇到了这样的问题。我有句点,每个对象都会更改这些句点。

代码语言:javascript
复制
const [period_waterfall] = useFetch('/company/' + firminfo.code + '/periods');

我把这段时间称为从那里开始,我发现周期的长度如下:

代码语言:javascript
复制
var length = period_waterfall.periods.length

我应该多次调用这个periods fetch (length的次数)。

我试过这个:

代码语言:javascript
复制
for (let i = 0; i < length; i++) {
        my_array.push(useFetch('/company/' + slug + '/waterfall?colIndexOffset=' + i))
      }

但是它会产生错误: React "useFetch“可能被执行不止一次。可能是因为它在循环中被调用。

我该怎么处理呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-11-26 06:50:32

你想在循环中调用一个钩子。这是一种不好的做法,是不允许的。钩子应该总是在最高层被调用。

您还在使用预定义的钩子进行数据检索。这个钩子是用来取一个东西的。按照您的特定顺序,您需要在循环操作中这样做,这意味着您使用的钩子不符合您的需要。

您可以做的是创建一个函数来执行抓取,而不是使用钩子。我喜欢使用axios。

代码语言:javascript
复制
const getPeriods = async (offset, slug) => {
  const url = '/company/' + slug + '/waterfall?colIndexOffset=' + offset
  const response = await axios.get(url)
  return response.data
}

在此函数中,您将获取1项。您可以重写它,以便在其中执行循环操作,或者在循环中调用它。

代码语言:javascript
复制
for (let i = 0; i < length; i++) {
  my_array.push(await getPeriods(i, slug)
}

注意,循环使用的是await,这意味着它需要在异步函数中。如果你不想那样做,你可以做这样的事情:

代码语言:javascript
复制
getPeriods(i, slug).then((res) => {
  my_array.push(res.data)
}

希望这有助于解决你的问题。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70120137

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档