[英]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.