它们如何在一起工作?
最后更新于:2022-04-01 04:30:53
## 它们如何在一起工作?
接下来看看这些角色是如何在一起工作的。
### 开始
首先在应用启动时:启动只有一次。
1. Store 告知 Dispatcher 只要有 action 产生就通知它。
data:image/s3,"s3://crabby-images/00692/006929efc0f26ecebbfe61bbf6853a578e127c9e" alt=""
2. Controller View 从 Store 中获取最新的 state。
3. 当 Controller View 接到来自 store 的 state,就将其传递给它所管辖的子 View 去渲染。
data:image/s3,"s3://crabby-images/347f5/347f5d65381cf8f98fa361ebfd1de78b3fb4032e" alt=""
4. Controller View 同时让 store 在 state 变化的时候通知自己。
data:image/s3,"s3://crabby-images/ee151/ee1519c6fe34fd4c83b377cb4c503e5dd6dd9076" alt=""
### 数据流
应用启动后,就准备好接受用户的输入了。现在我们让用户做一些操作,触发一个 action。
data:image/s3,"s3://crabby-images/0d85f/0d85f1fd806b861196f1b0152278e1fa0f78deb1" alt=""
用户交互我们就产生一次数据流。
1. View 告知 Action Creator 准备一个 action。
data:image/s3,"s3://crabby-images/b45b0/b45b06bd6b2df366388fe8c9a9edc556646c4306" alt=""
2. Action Creator 做好 action 并将其发送给 Dispatcher。
data:image/s3,"s3://crabby-images/416da/416da88247b12484238808c2e1bee203172fed98" alt=""
3. Dispatcher 按照顺序将 action 传递给 store。每一个 store 都会受到所有的 action 通知,然后自行觉得是否对这个 action 做出响应,更新 state。
data:image/s3,"s3://crabby-images/4c12f/4c12f15a0f171c47d3aaa0bd8e0f6fa61dccadac" alt=""
4. 一旦 store 更新 state 完毕,就会告知订阅了该 store 的 controller view。
5. 这些 controller view 就会向 store 请求更新了的 state。
data:image/s3,"s3://crabby-images/86d28/86d281b42f84506861ce3372e0fa64e78eb3df3b" alt=""
6. 从 store 中获得 state 之后,view controller 将会让它所管辖的子 view 渲染新的 state。
data:image/s3,"s3://crabby-images/b8913/b8913e02e53c4b8acd1d59512b934f183ffc6de4" alt=""
好了,这些就是我对 Flux 的理解,希望能够帮助到你!