Vuex中State的使用方法

 更新时间:2023年11月13日 10:20:35   作者:mumuwei_l  
这篇文章主要介绍了Vuex中State的使用方法,Vuex 使用单一状态树,用一个对象就包含了全部的应用层级状态,这也意味着,每个应用将仅仅包含一个 store 实例,需要的朋友可以参考下

前言

Vuex 使用单一状态树,用一个对象就包含了全部的应用层级状态。

这也意味着,每个应用将仅仅包含一个 store 实例。

单一状态树让我们能够直接地定位任一特定的状态片段,在调试的过程中也能轻易地取得整个当前应用状态的快照。

一、在 Vue 组件中使用 Vuex

Vuex 通过 store 选项,提供了一种机制将状态从根组件“注入”到每一个子组件中(需调用 Vue.use(Vuex)):

// 根组件
const app = new Vue({
  el: '#app',
  // 把 store 对象提供给 “store” 选项,
  // 这可以把 store 的实例注入所有的子组件
  store,
  components: { Counter },
  template: `
    <div class="app">
      <counter></counter>
    </div>
  `
})

通过在根实例中注册 store 选项,该 store 实例会注入到根组件下的所有子组件中,且子组件能通过 this.$store 访问到。让我们更新下 Counter 的实现:

// 子组件
const Counter = {
  template: `<div>{{ count }}</div>`,
  computed: {
    count () {
      return this.$store.state.count
    }
  }
}

二、mapState 辅助函数 使用Vuex

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

// 在单独构建的版本中辅助函数为 Vuex.mapState
import { mapState } from 'vuex'

export default {
  data() {
  	return {
  		localCount: 1
  	}
  },
  computed: mapState({
    // 箭头函数可使代码更简练
    count: state => state.count,

    // 传字符串参数 'count' 等同于 `state => state.count`
    countAlias: 'count',

    // 若想使用组件内 data 中定义的局部变量,必须使用常规函数
    countPlusLocalState (state) {
      return state.count + this.localCount
    }
  })
}

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

// 映射 this.count 为 store.state.count
// 使用时,按照计算属性使用即可 this.count
computed: mapState(['count'])

三、对象展开运算符

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

// 使用按照计算属性用法  直接 this.count ,this.num
// 插值表达式 {{ count }}, {{ num }}
computed: {
  ...mapState(['count', 'num'])
}

到此这篇关于Vuex中State的使用方法的文章就介绍到这了,更多相关Vuex中State内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 解决vue中el-tab-pane切换的问题

    解决vue中el-tab-pane切换的问题

    这篇文章主要介绍了解决vue中el-tab-pane切换的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • Element 头像上传的实战

    Element 头像上传的实战

    头像上传在很多实例中都可以用到,本文主要介绍了Element 头像上传,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • 深入详解Vue3实现多环境配置与切换方式

    深入详解Vue3实现多环境配置与切换方式

    这篇文章主要为大家详细介绍了Vue3中实现多环境配置与切换方式的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2025-09-09
  • Vue 绑定style和class样式的写法

    Vue 绑定style和class样式的写法

    class 与 style 绑定就是专门用来实现动态样式效果的技术,如果需要动态绑定 class 或 style 样式,可以使用 v-bind 绑定,本文给大家讲解Vue 绑定style和class样式,感兴趣的朋友一起看看吧
    2023-10-10
  • 前端vue2中直接拉起vnc客户端实现方式

    前端vue2中直接拉起vnc客户端实现方式

    本文介绍Vue项目中协议检测工具类与组件的实现,通过封装检测逻辑提升复用性,并展示如何在组件中应用工具类进行协议校验与数据展示
    2025-08-08
  • 解决vue3中内存泄漏的问题

    解决vue3中内存泄漏的问题

    在项目中会发现一个奇怪的现象,当我们在使用element-plus中的图标组件时会出现内存泄漏,所以本文讲给大家讲讲如何解决vue3中的内存泄漏的问题,需要的朋友可以参考下
    2023-07-07
  • Vue修改iview组件的样式的两种方案(element同)

    Vue修改iview组件的样式的两种方案(element同)

    使用vue必然会用到等iview组件库,但是iview的组件的样式跟自己写的div的样式修改不太一样,所以本文给大家介绍了Vue修改iview组件的样式的两种方案(element同),需要的朋友可以参考下
    2024-04-04
  • Element-UI 10个技巧小结

    Element-UI 10个技巧小结

    本文主要介绍了Element-UI 10个技巧小结,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • vue操作dom元素的3种方法示例

    vue操作dom元素的3种方法示例

    这篇文章主要给大家介绍了关于vue操作dom元素的3种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Vue渲染失败的几种原因及解决方案

    Vue渲染失败的几种原因及解决方案

    这篇文章主要介绍了Vue渲染失败的几种原因及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06

最新评论