关于状态管理模式

一个简单的 Vue 计数应用:

new Vue({
  // state
  data () {
    return {
      count: 0
    }
  },
  // view
  template: `
    <div>{{ count }}</div>
  `,
  // actions
  methods: {
    increment () {
      this.count++
    }
  }
})

该状态自管理应用包含以下几个部分:

  • state驱动应用的数据源

  • view以声明方式将 state 映射到视图

  • actions响应在 view 上的用户输入导致的状态变化

以下是一个表示“单向数据流”理念的简单示意:

当遇到多个组件共享状态时,单向数据流的简洁性容易被破坏:

  • 多个视图依赖于同一状态

  • 来自不同视图的行为需要变更同一状态

因此,如果把组件的共享状态抽取出来,以一个全局单例模式管理,在这种模式下,组件树构成一个巨大的“视图”,不管在树的哪个位置,任何组件都能获取状态或触发行为,而且代码也会变得更结构化、易维护。

这就是 Vuex 背后的基本思想,Vuex 是专门为 Vue.js 设计的状态管理库,以利用 Vue.js 的细粒度数据响应机制来进行高效的状态更新。

 

posted @ 2019-07-30 17:54  Leophen  阅读(972)  评论(0编辑  收藏  举报