1、如果要获取store里面的state的city属性。首先来看看没有使用mapState的情况      

  {{this.$store.state.city}}

再来看看使用mapState后   {{this.city}}

那么为什么会这样呢?先来看看官方的定义:

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

首先什么是状态?即state,state又是用来存储一些数据的,所以不难理解。

// store.js

/* vuex的核心管理对象模块:store  */
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)
// 状态对象
const state = { // 初始化状态 这里放置的状态可以被多个组件共享
  count: 1,
  name: 'daming'
}
const mutations = {}
const action = {}
const getters = {}

export default new Vuex.Store({
  state, // 状态
  mutations, // 包含多个更新state函数的对象
  actions, // 包含多个队形事件回调函数的对象
  getters // 包含多个getter计算属性函数的对象
})


2、代码中使用

import {mapState} from "vuex"
// 使用mapState, 此时,city已经被映射了,所以可以直接使用 this.city 去获取属性值
computed:{
    //意思是将vuex中的city数据映射到组件的computed属性里
    ...mapState(["city"])
}

1. html 中直接使用 city
2. js中使用 this.city


3.第三种使用方式

        还有一种使用方法,意思是将store里面的state里面的city属性映射到computed属性中的 currentCity 中。即 currentCity 代表了 $store.state.city  

​​computed:{ ...mapState({ currentCity:"city" }) }​​

1.使用 Vuex 并不意味着你需要将所有的状态放入 Vuex。虽然将所有的状态放到 Vuex 会使状态变化更显式和易调试,但也会使代码变得冗长和不直观。

2.如果有些状态严格属于单个组件,最好还是作为组件的局部状态。你应该根据你的应用开发需要进行权衡和确定。

3.由于 Vuex 的状态存储是响应式的,所以可以使用计算属性来获得某个状态

4.当状态改变时,都会重新求取计算属性,并且触发更新相关联的 DOM

5.通过下面的计算属性,就可以在当前组件中访问到count,name,nameAlias等了 在模板中我们通过大括号符号打印出来。 


 

4.在组件中提交 Mutation
你可以在组件中使用 this.$store.commit(‘xxx’) 提交 mutation,或者使用 mapMutations 辅助函数将组件中的 methods 映射为 store.commit 调用(需要在根节点注入 store)。

import { mapMutations } from 'vuex'

export default {
  // ...
  methods: {
    ...mapMutations([
      'increment', // 将 `this.increment()` 映射为 `this.$store.commit('increment')`

      // `mapMutations` 也支持载荷:
      'incrementBy' // 将 `this.incrementBy(amount)` 映射为 `this.$store.commit('incrementBy', amount)`
    ]),
    ...mapMutations({
      add: 'increment' // 将 `this.add()` 映射为 `this.$store.commit('increment')`
    })
  }
} 



若是按照模块来写的,只需在前面加上模块的名字,如上中的第三个:

   ...mapMutations("moudleA"{
      add: 'increment' // 将 `this.add()` 映射为 `this.$store.commit('/moudleA/increment')`
    })

 

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐