为了账号安全,请及时绑定邮箱和手机立即绑定

window.addEventListener 未按预期更新状态

window.addEventListener 未按预期更新状态

慕森卡 2023-11-11 15:57:41
我想从头开始构建无限滚动。这是代码:import React,{useEffect, useRef, useState} from 'react';const Container:React.FC<{}> = () => {  const containerRef = useRef<HTMLDivElement | null>(null)  const [ scrollNumber, setScrollNumber ] = useState<number>(1);  const [posts, setPosts] = useState<any[]>([]); useEffect(() => {  async function main(){      const req = await  fetch('https://jsonplaceholder.typicode.com/posts');      const result = await req.json();      const pst = result.splice(0,10*scrollNumber);      setPosts(pst)    function scrollHandler(){   if(containerRef.current?.getBoundingClientRect().bottom === window.innerHeight){          console.log("Salam", scrollNumber);          setScrollNumber(scrollNumber + 1);        }  }  window.addEventListener("scroll", scrollHandler);  return () => window.removeEventListener("scroll", scrollHandler);  }  main()},[]) useEffect(() => {  const loadData = async () => {    const req = await  fetch('https://jsonplaceholder.typicode.com/posts');    const result = await req.json();    const pst = result.splice(0,10*scrollNumber);    setPosts(pst)  }  loadData() },[scrollNumber])  return (    <div  ref={containerRef}>      {posts.map(post => (        <div key={post.id}>          <br/>          <h1>{post.title}</h1>      (<p>{post.body}</p>)      <code>{post.userId}</code>      <br/><br/>      <hr/>        </div>      ))}    </div>  )}export default Container但有一个问题。当我测试它时。它总是更新为 2 没有其他。我搜索了一下。我发现window.addEventListener只记住initialState,这就是state总是更新为2的原因。但我找不到任何代码解决方案。
查看完整描述

1 回答

?
当年话下

TA贡献1890条经验 获得超9个赞

在第一个useEffect依赖数组中是空的,这意味着如果您在其中使用任何状态变量,它的值不会在效果中改变


正如我所看到的,您正在使用scrollNumber设置的下一个状态setScrollNumber(scrollNumber + 1);和值scrollNumber不会改变内部效果,因为依赖项数组为空


因此,如果您对效果进行了任何更改,您必须告诉反应重新初始化效果scrollNumber


所以scrollNumber作为一个依赖项会为你工作


 useEffect(() => {

     ...


    function scrollHandler(){

        if(containerRef.current?.getBoundingClientRect().bottom === window.innerHeight) {

            console.log("Salam", scrollNumber);

            setScrollNumber(scrollNumber + 1);

        }

    }


    window.addEventListener("scroll", scrollHandler);

    return () => window.removeEventListener("scroll", scrollHandler);


.....

}, [scrollNumber]) //add a dependency


查看完整回答
反对 回复 2023-11-11
  • 1 回答
  • 0 关注
  • 147 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信