useConext or redux or 状态提升?

2021-08-20 11:43:22 +08:00
 ChrisV5

举例一个场景

上面是一堆的开关过滤器, 输出一堆参数给 Data 过滤
<FilterArea/>
下面是一个 table 展示数据
<DataArea/>

这种会影响代码可读性吧,毕竟 FilterArea 比较偏 UI,可能写在各种表现形式上

各位是用哪种?

3046 次点击
所在节点    React
27 条回复
ChrisV5
2021-08-20 11:54:46 +08:00
这种不算父子组件传值,算是兄弟组件传值?
ChrisV5
2021-08-20 12:08:01 +08:00
redux 还有一个问题是全局数据。就意味着你有多个比较相似的 Filter 的时候,用一套 type&reducers 就会互相污染,用多套,代码就写恶心了。

感觉这种更类似于上下文数据,应该用 Lifting State Up
walpurgis
2021-08-20 12:12:57 +08:00
兄弟组件共享显然是把状态提升到父级
statumer
2021-08-20 12:30:41 +08:00
状态提升,这个业务建议别写 redux 写 mobx,别和自己过不去
Rocketer
2021-08-20 13:51:15 +08:00
99%的项目不需要 redux,useContext 足够了。有机会做那 1%的人也不会来问这种问题。

所以,若非接手现有的代码,不要考虑 redux,开发速度慢,运行速度慢,太重了
XTTX
2021-08-20 14:25:55 +08:00
1.除非参数在 app 各个地方都有用到, 不然 props 传输就是最好的办法。
2.如果<DataArea/>的所需参数除了<FilterArea/>能输出,还有其他地方也能输出,props 也是最好的办法。
wuchangming89
2021-08-20 15:31:24 +08:00
@statumer,同意,写业务项目直接 Mobx,业务与 UI 分离,MVVM 效率也高。如果写开源库组件库什么的另说
dcalsky
2021-08-20 15:39:30 +08:00
其实 mobx 写起来也蛮快的,编码效率跟 useContext 差不多,关键是还不用自己填一堆坑。
zoeliu
2021-08-20 15:48:52 +08:00
状态提升 context 就可以。最近有复杂度不高的项目涉及全局状态传递使用的 useContext + useReducer 。
seki
2021-08-20 15:52:54 +08:00
recoil 或者 jotai
GuguDan
2021-08-20 16:07:02 +08:00
Stook
bnm965321
2021-08-20 16:13:21 +08:00
recoil 谁用谁知道
hingle
2021-08-20 17:02:34 +08:00
recoil + 1
PeakFish
2021-08-20 17:11:37 +08:00
各位 eventBus 怎么样?
@bnm965321
@dcalsky
@wuchangming89
wuchangming89
2021-08-20 17:20:54 +08:00
eventBus 和 redux 这些全局变量类的数据管理方案,模块化都不好做,命名空间约定也是麻烦事。如果大项目或者多人合作项目,模块化还是挺重要的。小项目除外,小项目上面说的什么都行。
ZZITE
2021-08-20 17:34:32 +08:00
recoil + 1
prayx
2021-08-20 18:06:14 +08:00
推荐个冷漠的库 constate:
将自定义 hooks 提升到 context
特别简洁优雅
Rocketer
2021-08-21 00:16:06 +08:00
另外说一句,如果可以选择的话,别用 react,试试 angular 。

三大 spa 框架我都用过,angular 是最完善的,全套官方功能即可满足绝大多数项目需求,不像 react 还得用一堆第三方库
sjhhjx0122
2021-08-21 11:47:10 +08:00
@Rocketer angular 一个 service 配合 rxjs 就能解决实在是舒服
SHF
2021-08-21 18:32:30 +08:00
你需要把状态和组件解耦,抽象到一个 model 里,现实情况中有很多逻辑和数据和组件是正交的,多个组件会用多个属性

可以试试我写的这个:
react-object-model - 面向对象的 React 状态管理库
1. 轻量,基于 useState (返回的 setState 具有引用稳定性,可区分组件,调用时能够触发渲染) 和 useEffect (组件卸载时清理订阅关系)
2. API 简洁、符合直觉,const { name, age } = user.use(['name', 'age']) 即可在 React 组件中完成对 user 模型中 name, age 属性的订阅; user.set({ name: 'Tom' }) 即可更新 user 模型的 name 属性并触发组件渲染
3. 根据每个组件订阅的模型属性做 diff,与上次相比改变后才更新组件状态,避免不必要的渲染

https://github.com/ShenHongFei/react-object-model

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

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

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

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

© 2021 V2EX