首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Reactjs无穷大滚动组件总是呈现新数据。

Reactjs无穷大滚动组件总是呈现新数据。
EN

Stack Overflow用户
提问于 2020-12-26 10:12:32
回答 1查看 73关注 0票数 0

滚动后,我的数据总是呈现到页面2页面1消失,并且items.concat无法工作。

获取数据代码:

代码语言:javascript
复制
const FetchUrl = async (p) =>{
    const Url = await fetch(`api-link=${p}`);
    const data = await Url.json();
    setItem(data.DataNonProject.data)
}

获取更多数据的代码:

代码语言:javascript
复制
const fetchMoreData = () => {
    setTimeout(() => {
        setPage(page + 1);
        console.log(page);
        FetchUrl(page);
        setItem(items.concat(Array.from(items)));
    }, 100);
    // FetchUrl(page);
 }

返回数据:

代码语言:javascript
复制
{items ? 
    <InfiniteScroll
      dataLength={items.length}
      next={fetchMoreData}
      hasMore={true}
      loader={<h4>Loading...</h4>}
    >
     {console.log(items)}   
        { items.map((item, index) => (
            <div key={index}>
                div {index} - # {item.title}
                <br/><br/><br/>
            </div>
        ))}
    </InfiniteScroll>
    : '' }

我用的是react-infinite-scroll-component

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-12-26 10:16:26

代码语言:javascript
复制
const FetchUrl = async (p) =>{
  const Url = await fetch(`https://softkomik.site/api/komik-list?page=${p}`);
  const data = await Url.json();
  setItem(prev => [...prev, ...data.DataNonProject.data])
}
代码语言:javascript
复制
const fetchMoreData = () => {
    setTimeout(() => {
        setPage(page + 1); // At this point, page state will not be changed because setPage is async function
        FetchUrl(page + 1);
    }, 100);
 }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65455313

复制
相关文章

相似问题

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