vuex(三)之辅助函数

简介: vuex(三)之辅助函数

一、mapState

当一个组件需要获取多个状态的时候,通过this.$store.state来声明就会显得有些重复跟冗余,通过mapState这个辅助函数可以帮助生成计算属性。
在store文件中定义state

//  store.js存放数据
state:{
    number1:1,
    number2:2
}

如何使用

//方式一(不推荐)
<template>
    {{$store.state.number1}}
    {{$store.state.number2}}
</template>
//方式二(计算属性)
<template>
    {{number1}}{{number2}}
</template>
computed:{
    number1(){
      return this.$store.state.number1
    },
    number2(){
      return this.$store.state.number2
    }
}
//方式三(辅助函数)
//在组件中使用mapState,放置在computed里面。
//项目中常用的方式
// App.vue
<template>
  <div>
    <h1>{{number1}}</h1>
    <h1>{{number2}}</h1>
  </div>
</template>
import { mapState } from 'vuex'
export default{
    computed:{
        ...mapState(['number1','number2']) // 在组件通过this就可调用,不用再写this.$store.state
        // ...mapState({ 另一种写法
        //   number1: state=>state.number1,
        //   number2: state=>state.number2
        // }),
    }
}

二、mapGetters

//方式一(不推荐)
<template>
    {{$store.getters.GET_BOOK_NUM}}
</template>
//方式二(计算属性)
<template>
    {{GET_BOOK_NUM}}
</template>
computed:{
    GET_BOOK_NUM(){
      return this.$store.getters.GET_BOOK_NUM
    }
}
//方式三(辅助函数)
//项目中常用的方式
<template>
    {{GET_BOOK_NUM}}
</template>
import {mapGetters} from 'vuex'
computed:{  
      ...mapGetters(['GET_BOOK_NUM'])  
}

三、mapMutations

mapMutations 其实跟mapState、mapGetters 的作用是类似的,将组件中的 methods 映射为store.commit 调用。

在store文件中定义mutations

//  store.js
  mutations:{
    changeNumber1(state, val){
      state.number1 += val
    },
    changeNumber2(state, val){
      state.number2 += val
    },
  },

每一个mutation接受两个参数,一个是state,一个是传入值;

在组件中使用mapMutations,放置在methods里面。

// App.vue
<template>
  <div>
    <h1>{{number1}}</h1>
    <h2 @click="changeNumber1">+{{number1}}</h2>
    <h1>{{number2}}</h1>
    <h2 @click="changeNumber2">+{{number2}}</h2>
  </div>
</template>
import { mapMutations } from 'vuex'
export default{
  computed:{
        ...mapState(['number1','number2']) 
  }
  methods:{
    ...mapMutations(['changeNumber1','changeNumber2']),
  }
  //映射 this.changeNumber1() 为 this.$store.commit('changeNumber1')
  //映射 this.changeNumber2() 为 this.$store.commit('changeNumber2')
}

四、mapActions

mapActions将组件中的 methods 映射为store.dispatch 调用。

在store文件中定义actions

//  store.js
  mutations:{
    changeNumber1(state, val){
      state.number1 += val
    },
    changeNumber2(state, val){
      state.number2 += val
    },
  },
  actions:{
    changeNumber1Action(context,val){
      context.commit('changeNumber1',val);
    },
    changeNumber2Action(context,val){
      context.commit('changeNumber2',val);
    }
  }

每一个action接受两个参数,一个是context(上下文),一个是传入值;

在组件中使用mapActions,放置在methods里面。

// App.vue
<template>
  <div>
    <h1>{{number1}}</h1>
    <h2 @click="changeNumber1Action">+{{number1}}</h2>
    <h1>{{number2}}</h1>
    <h2 @click="changeNumber2Action">+{{number2}}</h2>
  </div>
</template>
import { mapActions} from 'vuex'
export default{
  methods: {
    ...mapActions([
      'changeNumber1Action','changeNumber2Action'
    ]),
     //映射 this.changeNumber1Action() 为 this.$store.dispatch('changeNumber1Action')
     //映射 this.changeNumber2Action() 为 this.$store.dispatch('changeNumber2Action')
  }
相关文章
|
8月前
|
存储 JavaScript 开发者
Pinia和Vuex的区别
Pinia和Vuex的区别
1801 0
|
3月前
|
存储 JavaScript API
Vuex 和 Pinia 的区别
【10月更文挑战第18天】Vuex 和 Pinia 都有各自的优势和适用场景。Vuex 适合较为大型和复杂的项目,强调严格的架构和流程;而 Pinia 则更适合中小型项目以及对灵活性和简洁性有更高要求的开发者。你可以根据项目的具体需求和个人喜好来选择使用哪一个状态管理库。
731 59
|
6月前
|
监控 JavaScript
VUEX 使用学习三 : mutations
VUEX 使用学习三 : mutations
37 0
|
8月前
|
JavaScript 前端开发 中间件
vuex/redux的区别
vuex/redux的区别
116 2
|
8月前
|
存储 JavaScript
vuex的基本用法
Vuex是Vue.js的状态管理库,用于集中存储和管理共享状态。通过创建Vuex store实例,定义`state`(如`count`)和`mutations`(如`increment`),组件可使用`this.$store.state`访问状态,`this.$store.commit`修改状态。当应用复杂时,可将状态分割成带命名空间的模块,如`cart`,组件内通过`this.$store.state.cart`和`this.$store.commit(&#39;cart/addItem&#39;)`进行访问和修改。
|
8月前
|
存储 JavaScript
vuex和pinia区别
vuex和pinia区别
473 0
|
8月前
|
存储 JavaScript 前端开发
Vuex 和 Redux 的区别?
Vuex 和 Redux 的区别?
107 1
|
8月前
|
存储 JavaScript
Vuex和Redux的区别
Vuex和Redux的区别
|
8月前
|
缓存 JavaScript
vuex的讲解与相关用法
vuex的讲解与相关用法
34 0
|
8月前
|
存储 JavaScript 前端开发
redux和Vuex的使用与区别
redux和Vuex的使用与区别
82 0