如何解决为什么我的React程序没有获得状态变量的最新版本?
我正在研究a program,它获取SVG并将其转换为一组具有交互性的React组件。
我遇到的问题是在构建树时注册的onClick
处理程序未获取状态变量的更新版本。
在我的buildTree
函数中,我有以下代码:
⋮
if(["key"].includes(attrs.className)) {
setKeys((ks) => [...ks,attrs.ref])
attrs.onClick = (evt) => clickShow(evt.target,attrs.ref.current)
}
return React.createElement(root.nodeName,attrs,children)
但是,当我单击时,keys
变量为空数组。
This pen演示了此问题。关键是左下角的一所房子的小图片。单击地板应该可以更改视图,但是正如您在控制台中看到的那样,keys
是一个空数组。
解决方法
我发现this answer可以解释我遇到的范围问题,并且我可以使用useRef
来获取适当的可变变量。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。