State

1. 前言

本小节我们将学习和使用 Vuex 中 state 的概念。包括如何创建 state、组件中获取 state、以及辅助函数 mapState 的使用方法。

2. 创建数据仓库

在上一小节中,我们已经给大家写了一个简单的示例,大家一定还记得 Vuex.Store({...}) 这个方法。在 Vuex 中,我们通过该方法创建一个数据仓库,并把数据 state 传入。例如:

const store = new Vuex.Store({
  state: {
    count: 12000,
    name: '慕课网',
    logo: ''
  }
})

那么,创建完数据仓库后,我们怎样才能在 Vue 组件中使用它呢?我们知道,要使用 Vue 需要通过 new Vue () 创建一个 Vue 实例,并传入对象的参数。要在 Vue 中使用 store,只需要在创建 Vue 实例的时候将 store 传入即可:

var vm = new Vue({
  el: '#app',
  store: store
})

3. 在 Vue 组件中获得 Vuex 状态

那么我们如何在 Vue 组件中展示状态呢?由于 Vuex 的状态存储是响应式的,从 store 实例中读取状态最简单的方法就是在计算属性中返回某个状态:

代码解释
JS 代码第 4-8 行,我们定义了仓库 store。
JS 代码第 11 行,创建 Vue 实例的时候传入 store。
JS 代码第 13-15 行,利用计算属性返回 count。
HTML 中利用插值显示 count 的数据。

4. mapState 辅助函数

当一个组件需要获取多个状态时候,将这些状态都声明为计算属性会有些重复和冗余。为了解决这个问题,我们可以使用 mapState 辅助函数帮助我们生成计算属性:

代码解释
JS 代码第 4-9 行,我们定义了仓库 store。
JS 代码第 12 行,创建 Vue 实例的时候传入 store。
JS 代码第 18-28 行,利用计算属性分别返回 name、age、countPlusAge。

当映射的计算属性的名称与 state 的子节点名称相同时,我们也可以给 mapState 传一个字符串数组。

computed: Vuex.mapState([
  // 映射 this.age 为 store.state.age
  'age',
   // 映射 this.name 为 store.state.name
  'name'
])
// ===等同于===
computed:  Vuex.mapState({age:'age', name: 'name'})
//

5. 对象展开运算符

mapState 函数返回的是一个对象。我们如何将它与局部计算属性混合使用呢?通常,我们需要使用一个工具函数将多个对象合并为一个,以使我们可以将最终对象传给 computed 属性。但是自从有了对象展开运算符,我们可以极大地简化写法:

computed: {
  localComputed () { /* ... */ },

  // 使用对象展开运算符将此对象混入到外部对象中
  ...Vuex.mapState({
    // ...
  })
}

6. 小结

本节,我们带大家学习了 Vuex 中 state 的使用方式。主要知识点有以下几点:

  • 在 store 中定义 state 数据。
  • 通过 $store.state 访问 state 中的数据。
  • 使用 mapState 辅助函数简化获取 state 中数据的写法。
本文来自互联网用户投稿,不拥有所有权,该文观点仅代表作者本人,不代表本站立场。
访问者可将本网站提供的内容或服务用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯本网站及相关权利人的合法权利。
本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站,邮箱:80764001@qq.com,予以删除。
© 2023 PV138 · 站点地图 · 免责声明 · 联系我们 · 问题反馈