繁体   English   中英

组件不会在状态更改时重新呈现

[英]Components not re render on state change

我正在尝试更新列表的状态。 并且需要根据ids状态重新呈现列表。 但是 array 需要参考值,每次我用setIds更新ids时,我无法获得更新的列表,因为组件没有重新渲染。 无论如何要实现这一点。 我尝试添加const [idsLength, setIdsLength] = useState(0)并在列表中传递和更新它。 但我觉得有一个更好的方法。

const Component1 = () => {
  const [ids, setIds] = useState([]);
  
  const handleIdClick = () => {
    const temp = ids
    temp.push(ids.length)
    setIds(temp)
    console.log(ids)
  }
  
  return(
    <div>
        <div onClick={handleIdClick}>
            Id Adder
        </div>
        {ids.map(id=>{
            return(
                <div key={id}>
                    {id}
                </div>
            )
        })}
    </div>
  )
}

你只需要使用useEffect钩子

  useEffect(() => {
    console.log("ids :" + ids);
  }, [ids]);

您可以创建一个包含更新内容的新数组并将其传递给setIds

const handleIdClick = useCallback(() => {
    setIds([...ids, ids.length]);
}, [ids])

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM