|
VUE简单状态管理起步使用
5 p* z+ s3 }2 D# E+ \/ U
. h8 m, A/ A, p; G9 m9 T, q* y经常被忽略的是,Vue 应用中响应式 data 对象的实际来源——当访问数据对象时,一个组件实例只是简单的代理访问。所以,如果你有一处需要被多个实例间共享的状态,你可以使用一个 reactive 方法让对象作为响应式对象。需要注意,所有 store 中 state 的变更,都放置在 store 自身的 action 中去管理。这种集中式状态管理能够被更容易地理解哪种类型的变更将会发生,以及它们是如何被触发。当错误出现时,我们现在也会有一个 log 记录 bug 之前发生了什么。此外,每个实例/组件仍然可以拥有和管理自己的私有状态:重要的是,注意你不应该在 action 中替换原始的状态对象——组件和 store 需要引用同一个共享对象,变更才能够被观察到。接着我们继续延伸约定,组件不允许直接变更属于 store 实例的 state,而应执行 action 来分发 (dispatch) 事件通知 store 去改变,我们最终达成了 Flux状态管理 - 图7 (opens new window) 架构。这样约定的好处是,我们能够记录所有 store 中发生的 state 变更,同时实现能做到记录变更、保存状态快照、历史回滚/时光旅行的先进的调试工具。' |, l- P0 h4 ]) p( r; u9 I
; C8 n; b3 x) ?/ v1 W& I2 {. b
4 s. u7 t: |6 X) `8 m$ G
8 v0 ^7 x) I" q9 x" X$ O
原文连接:http://www.szw86.com/thread-9192-1-1.html |
|