它们如何在一起工作?

最后更新于:2022-04-01 04:30:53

## 它们如何在一起工作? 接下来看看这些角色是如何在一起工作的。 ### 开始 首先在应用启动时:启动只有一次。 1. Store 告知 Dispatcher 只要有 action 产生就通知它。 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-10-27_562edca86783e.jpg) 2. Controller View 从 Store 中获取最新的 state。 3. 当 Controller View 接到来自 store 的 state,就将其传递给它所管辖的子 View 去渲染。 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-10-27_562edca87a7c4.jpg) 4. Controller View 同时让 store 在 state 变化的时候通知自己。 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-10-27_562edca89105c.jpg) ### 数据流 应用启动后,就准备好接受用户的输入了。现在我们让用户做一些操作,触发一个 action。 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-10-27_562edca8a322d.jpg) 用户交互我们就产生一次数据流。 1. View 告知 Action Creator 准备一个 action。 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-10-27_562edde1a8543.png) 2. Action Creator 做好 action 并将其发送给 Dispatcher。 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-10-27_562edca8ccc4c.jpg) 3. Dispatcher 按照顺序将 action 传递给 store。每一个 store 都会受到所有的 action 通知,然后自行觉得是否对这个 action 做出响应,更新 state。 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-10-27_562edca8df5ed.jpg) 4. 一旦 store 更新 state 完毕,就会告知订阅了该 store 的 controller view。 5. 这些 controller view 就会向 store 请求更新了的 state。 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-10-27_562edca902b7b.jpg) 6. 从 store 中获得 state 之后,view controller 将会让它所管辖的子 view 渲染新的 state。 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-10-27_562edca918b08.jpg) 好了,这些就是我对 Flux 的理解,希望能够帮助到你!
';