
当您使用 react 并拥有同一组件的多个实例时,管理状态可能会变得很棘手。根据组件需要交互的方式,您需要以不同的方式处理状态。这是我发现效果很好的方法。
如果您的组件不需要相互通信,最好将它们的状态保留在组件内。这样,每个实例都有自己的状态,其中一个实例的更改不会影响其他实例。
function counter() {
const [count, setcount] = usestate(0);
return (
<div>
<p>count: {count}</p>
<button onclick={() => setcount(count + 1)}>increment</button>
</div>
);
}
// usage
<counter /> // instance 1
<counter /> // instance 2
在这里,每个 counter 组件都会跟踪自己的计数。因此,如果您单击一个计数器中的按钮,则不会更改另一个计数器中的计数。
但是,如果组件需要共享某些状态或以协调的方式工作,最好将状态移至父组件。父级可以管理共享状态并将其作为 props 传递下来。这可确保所有实例保持同步并顺利协同工作。
function Parent() {
const [sharedCount, setSharedCount] = useState(0);
return (
<div>
<p>Total Count: {sharedCount}</p>
<Counter count={sharedCount} setCount={setSharedCount} />
<Counter count={sharedCount} setCount={setSharedCount} />
</div>
);
}
function Counter({ count, setCount }) {
return (
<div>
<p>Count: {count}</p>
<button onClick={() => setCount(count + 1)}>Increment</button>
</div>
);
}
这种方法之所以有效,是因为当状态位于父组件中时,对该状态的任何更新都会触发所有实例的重新渲染,确保它们都显示最新的 ui。如果将状态单独保存在每个实例中,则只有状态发生更改的实例才会重新渲染,从而导致实例之间的 ui 不一致。
我的项目中的示例
我在构建手风琴组件时发现了这一点。这是我自己工作中的两个例子:
本系统经过多次升级改造,系统内核经过多次优化组合,已经具备相对比较方便快捷的个性化定制的特性,用户部署完毕以后,按照自己的运营要求,可实现快速定制会费管理,支持在线缴费和退费功能财富中心,管理会员的诚信度数据单客户多用户登录管理全部信息支持审批和排名不同的会员级别有不同的信息发布权限企业站单独生成,企业自主决定更新企业站信息留言、询价、报价统一管理,分系统查看分类信息参数化管理,支持多样分类信息,
0
独立手风琴实例:示例。在此设置中,每个手风琴实例独立工作。
依赖的手风琴实例:示例。在此版本中,所有手风琴实例相互依赖并保持同步。
快速回顾
如果组件单独工作,请将状态保存在每个组件内。
如果他们需要共享状态或以协调的方式一起工作,请在父级中管理状态。
在构建这些手风琴示例时,这种方法对我产生了很大的影响。希望对你也有帮助!
以上就是在 React 中管理同一组件的多个实例中的状态的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号