React Context 应该怎么用?

2022-02-25 13:32:46 +08:00
 FaiChou

Context 可以跨层级传数据, 和 props 一样, 当 context 数据变动, Consumer 也会更新.

再一想, context 数据是怎么变化的? Context 数据绑定到 Provider 的 state 中, 需要 setState 来更新 context 数据, 那么 setState 会触发 re-render, 这样子组件自然也会刷新.

但感觉这种情况也不需要 Context 也能实现啊? 比如全局有一个 themeObj, 在最外层的监听这个 obj 的变化, 如果变化, 手动调用 forceUpdate, 这样子组件也会触发更新, 子组件只需要 import 这个 themeObj 使用即可, 每次 re-render 都会拿到最新的数据.

2141 次点击
所在节点    React
7 条回复
wobuhuicode
2022-02-25 13:45:12 +08:00
react 主张的是单向数据流的方式。
要是各种使用监听的去更新 view 的话,而且项目大了,数据多了,代码就会变得很难看。
FaiChou
2022-02-25 13:45:30 +08:00
coolzjy
2022-02-25 13:49:02 +08:00
context 基本就是这个思路,只不过你这样把状态放在全局的实现智能有一个 context ,如果要有多个的话要添加一堆 hack ,这样 hack 下来基本就是 react context 的样子了。
fernandoxu
2022-02-25 13:55:24 +08:00
你说的就是代理呗,有 valtio 还有 @ nanxiaobei 搞的类似东西
fernandoxu
2022-02-25 13:57:10 +08:00
https://github.com/jherr/which-react-state-manager

状态管理五花八门,想咋玩都行,看口味儿
CokeMine
2022-02-25 16:21:00 +08:00
手动 forceUpdate 不太优雅吧
而且 hook 要想 forceUpdate 也得借助于一个 useState 了
KuroNekoFan
2022-02-25 21:00:16 +08:00
因为 useContext 很舒服

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/836378

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX