目前遇到的组件通信都会使用 context 完成业务需求,感觉并不是必须使用全局状态管理。有大佬可以列举一下必须使用全局状态管理才能实现的需求嘛,感觉自己以前业务真的是强行使用的,并不是被逼的不得不用
1
Chad0000 2022-09-28 14:22:55 +08:00 via iPhone 2
使用 angular 从来没有这种顾虑
|
2
Promisei 2022-09-28 14:24:28 +08:00
两个没关系的组件都要使用到 token 用 redux 进行 token 管理
|
5
catchecken 2022-09-28 14:33:23 +08:00
@quehei context 的性能十分差.redux 可以做到按需更新组件.
|
6
quehei OP @catchecken redux 也是把 store 更新到 context 里啊,大家提升代码复杂度使用 redux 是为了提高组件性能?依据是什么呀
|
8
dk7952638 2022-09-28 14:50:20 +08:00
以我肤浅的实践来看,多层属性传递的嵌套组件用状态管理确实比较方便,他的场景暂时还没发现是必须的
|
9
whenov 2022-09-28 14:51:05 +08:00
Redux 产生的时期还不存在 Context API ,现在很多场景下应该可以不用 Redux 的
|
10
catchecken 2022-09-28 14:51:45 +08:00
@quehei 错,store 没有更新
|
11
catchecken 2022-09-28 14:53:02 +08:00
redux context Provider 的 value 没有更新
@quehei |
12
hua123s 2022-09-28 14:55:30 +08:00
zustand/jotai 才是正解,放弃 redux 吧。
|
14
wangxiaoaer 2022-09-28 14:57:49 +08:00
恕我直言,80%的前端页面(展示类、增删改查类)都用不到状态管理。
需要状态管理的是交互多并且存在联动的情况,比如在线 PS 、地图类等。 |
15
wangxiaoaer 2022-09-28 14:59:46 +08:00
@Chad0000 #1 Angular 当初尝试过,那个 module 系统就把我干蒙蔽了,TS/JS 本身的 import/export 再加上 ng 自己的 import/export ,一下就上天了。
|
16
quehei OP @Promisei 我的意思是在根组件或者 layout 这种地方挂 context ,不存在两个毫无关联的组件啊。使用 redux 不也是在根组件把 store 传到 context 里面
|
17
quehei OP @catchecken 传一个 valueChange 的方法在 value 里面是不是可以做到更新呢
|
18
TWorldIsNButThis 2022-09-28 15:02:59 +08:00
写过一个需求感觉比较合适,有个开会模式,开会时需要广播当前用户的所有状态(列表内容,过滤器选项等)和操作到其他用户上
然而这个需求是后来才提的,一开始搭架构的时候状态就是分散的,用 swr 管理请求的数据,最后也是把各个操作每个都加上同步 |
19
dsggnbsp 2022-09-28 15:08:24 +08:00
用不到就不用,不用随大流
|
20
catchecken 2022-09-28 15:17:45 +08:00
@quehei 是的.
redux 的顶层 context 传递的是 store 的包裹对象,这个对象的引用是不变的. 组件可以访问 store. 使用 redux 的组件感知 store 更新的原理是发布订阅.组件挂载的时候会订阅 store 更新.store 更新后订阅 store 的组件会自动更新. 跟 context 没有关系. |
21
ifdef 2022-09-28 15:24:32 +08:00
recoil 或者 jotai , 比 redux 更好用
|
23
shadeofgod 2022-09-28 15:30:13 +08:00
大部分时候不需要,Redux 在面临着比较高复杂度的应用里才能深刻体会到它的优势,另外现在使用 Redux 的标准姿势是直接使用 Redux Toolkit ,它的 API 设计和完善的类型让使用成本变得非常低而且体验上强很多
|
25
karott7 2022-09-28 15:52:53 +08:00
已经完全不用 redux 了,context + immer 就可以了
|
26
limi58 2022-09-28 15:58:36 +08:00 1
redux 这类的,可以拿来约束团队,如果用 context ,写法可能有 100 种,redux 的话就往对应的模块加东西就可以了
|
27
darlinghsu 2022-09-28 16:01:06 +08:00
redux 重要的一个点就是,到了要用的时候你就知道要用它了(指 需要它来解决数据管理的问题 如:多&杂
一般使用也确实可以不用 |
28
66beta 2022-09-28 16:01:36 +08:00
个人观点:
context:配置 redux:数据 /状态 |
29
gouflv 2022-09-28 16:43:30 +08:00 via iPhone
个人感觉,redux 的模式或者说约束,在大型项目中是成本最低的方案,对标 angular
|
30
cyberpoint 2022-09-28 16:48:22 +08:00
@limi58 是的
|
31
yor1g 2022-09-28 16:59:09 +08:00
工程化的东西 解耦 模版化 虽然繁琐但是整体更好控制 而且还有专门工具调试 小项目用了觉得没用
|
32
magichacker 2022-09-28 17:03:06 +08:00
我都用 Mobx
|
33
mmm159357456 2022-09-28 17:31:56 +08:00
竟然没人提 flutter
|
34
Baymaxbowen 2022-09-28 17:33:32 +08:00 via iPhone
一直都没用过 redux🫤
|
35
thulof 2022-09-28 17:41:56 +08:00
useContext 存在的问题是会有多余的重渲染
|
36
thulof 2022-09-28 17:43:14 +08:00
上面是指 value 是一个复杂对象的情况下
当然也可以拆成多个简单值,但是这样的话就要套一大堆的 Provider |
37
charlie21 2022-09-28 17:46:56 +08:00 via iPhone
耦合这些东西之后会非常 messy.
我设想的是,就页面状态保存而言,即然全站各个页面是从全站各个路由走到的,那么仅就页面状态保存而言,应该是基于全站路由的一个 map 。在全站各个路由载入对应的根组件之前,可以从 map 里找到此路由对应的根组件 将数据填充进去 这时候,状态缓存器是让 “第二次访问某路由” 的时候 和第一次访问此路由时有相同的状态。而这种模式如果被各个路由用到,那么 一个 service 就是必要的。而这种 service 就是:一个被注入各种组件到 service ,一个挂载到根组件到 service 。但它依然不必须是一个全局状态管理器 |
38
jymsy 2022-09-28 17:52:25 +08:00
context 只能在组件里用,我要在 service 里拿一个全局状态就废了(不通过传参的方式)。
|
39
linshuizhaoying 2022-09-28 17:54:17 +08:00
mobx 还是爽
|
40
zgk 2022-09-28 18:45:44 +08:00 1
redux 在 React Hooks 流行之前,class component 为主的时候,还是蛮普遍的,在 Hooks 流行以后顶部直接 useState / useReducer 已可以满足大部分不太重度的需求,就无需再引入太重型的状态管理库。
redux 模版代码一堆,redux-toolkit 虽然解决了一部分,但也有些臃肿,ts typing 有一定概率踩坑,都带着很多前一个时代的历史包袱。目前的话非集中式的 zustand / jotai / recoil 之类的会更合适些。 |
41
ChrisV5 2022-09-28 18:53:38 +08:00
一个图片审核类的项目,一次加载一页 180 张图片。会有多种过滤条件选项,和单个数据状态改变,操作多是批次操作,如果父子传值会带来子 card 的重绘,页面会非常卡。
|
42
buffzty 2022-09-28 20:11:13 +08:00
我一般用在全局状态上,比如用户登录状态,多语言设置
|
43
charlie21 2022-09-29 09:36:53 +08:00
@Chad0000 只要有一个依赖注入系统 (比如 inversify.js ),则任何框架都可以做到。 angular 是径直把它做到框架里了仅此而已
|
44
czgaotian 2022-09-29 10:42:00 +08:00
我也纳闷过这个问题,vue 里现在有 inject/provide ,我用了感觉也能覆盖业务需求,不知道啥时候能上 pinia
|
45
vivipure 2022-09-29 11:40:24 +08:00
推荐 zustand , redux 需要写的代码太多
|