|
VUE简单状态管理起步使用6 ]$ P2 \: Z, x( I5 ?0 }9 n5 f
( T; z. p/ O& y9 t9 |6 C" R
经常被忽略的是,Vue 应用中响应式 data 对象的实际来源——当访问数据对象时,一个组件实例只是简单的代理访问。所以,如果你有一处需要被多个实例间共享的状态,你可以使用一个 reactive 方法让对象作为响应式对象。需要注意,所有 store 中 state 的变更,都放置在 store 自身的 action 中去管理。这种集中式状态管理能够被更容易地理解哪种类型的变更将会发生,以及它们是如何被触发。当错误出现时,我们现在也会有一个 log 记录 bug 之前发生了什么。此外,每个实例/组件仍然可以拥有和管理自己的私有状态:重要的是,注意你不应该在 action 中替换原始的状态对象——组件和 store 需要引用同一个共享对象,变更才能够被观察到。接着我们继续延伸约定,组件不允许直接变更属于 store 实例的 state,而应执行 action 来分发 (dispatch) 事件通知 store 去改变,我们最终达成了 Flux状态管理 - 图7 (opens new window) 架构。这样约定的好处是,我们能够记录所有 store 中发生的 state 变更,同时实现能做到记录变更、保存状态快照、历史回滚/时光旅行的先进的调试工具。
5 u* E+ r9 Y) _; r$ l; u4 `) B3 E q8 {2 K2 u4 ~+ R; w; z: Y5 I
2 o9 w- z9 f" O0 m# h, x: {& [
2 i: P$ V, D: e6 Y原文连接:http://www.szw86.com/thread-9192-1-1.html |
|