一个关于 Electron + React 的问题咨询

2023-07-25 09:57:26 +08:00
 aapeli
Electron + React 渲染进程和主进程如何使用 redux 共享状态? 有没有啥方案或者包推荐的?
2003 次点击
所在节点    Node.js
13 条回复
lsk569937453
2023-07-25 10:06:23 +08:00
后端小白问下:

react 都有 hooks 了还需要用 redux 做什么用?

因为有一次我问我的前端同学用什么做状态管理,他说用 react hooks 就够了。。。。
zhuangpipi
2023-07-25 10:08:24 +08:00
很短暂的用过一段时间,考虑一下状态放主进程,然后自己封装一下和主进程通讯的方法用?
leuction
2023-07-25 10:11:35 +08:00
@lsk569937453 没有什么用,现在用 redux 主要还是历史遗留问题,除非你的状态过于复杂或者需要回放等功能,其他情况下根本不需要 redux
jchnxu
2023-07-25 10:21:26 +08:00
监听主进程的里面的状态对象,感觉是可行的
xianyu191031
2023-07-25 10:28:56 +08:00
把渲染进程同步主进程状态的行为理解成跟 web 开发中的异步后端调用就好了
yuyue001
2023-07-25 10:30:37 +08:00
印象中,这两个线程是独立的。不能直接共享数据。
但是 electron 提供了通信方式。你看看这个
进程间通信 https://www.electronjs.org/zh/docs/latest/tutorial/ipc
ljtfdt
2023-07-25 10:32:46 +08:00
主进程和渲染进程是隔离的,主进程是 node 环境,渲染进程是 web ,共享状态还是要靠进程间通讯来实现
leohxj
2023-07-25 10:43:44 +08:00
otakustay
2023-07-25 11:10:13 +08:00
你把主进程理解成后端,Electron 内部还是个前后端分离的系统,自然没有共享状态这事了,只是通信相比 HTTP 快很多
ChefIsAwesome
2023-07-25 11:18:46 +08:00
你就当做普通 web 开发,前后端分离,ipc 通讯就是调 api 。不要想着在一端就能搞定所有的。
lokitangl
2023-07-25 11:20:21 +08:00
我们之前的项目,直接搞了个 middleware ,每次 action 把 redux 状态通过 IPC 传到主进程里
这么干其实没必要,浪费资源
实际上只需要把需要用到的数据传到主进程就可以了
RealJacob
2023-07-25 12:03:00 +08:00
@lsk569937453 复杂状态管理个人认为还是 redux 更方便,尤其是一些基于 redux 封装的包。(可能也是遗留的使用习惯问题)。但是确实 context 和 reducer 可以解决大部分状态管理的问题
owen800q
2023-07-25 12:26:11 +08:00
eletronAPI

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

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

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

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

© 2021 V2EX