我对vuex的理解(二) 之 mapGetters取值和mapMutations的传参

简介: 前言:最近在做一个vue的项目,碰到一点关于mapMutations传参的问题,解决完问题了所以写一下对它理解。1、官网中的提交载荷(传参)具体到一般demo中大概是这样的const store new Vuex.

前言:最近在做一个vue的项目,碰到一点关于mapMutations传参的问题,解决完问题了所以写一下对它理解。

1、官网中的提交载荷(传参)具体到一般demo中大概是这样的

const store new Vuex.Store({
    state: {
        count: 0
    },
    mutations: {
        increment(state,n){
            state.count += n
        }
    }
})

new Vue({
    el:"#app",
    store,
    computed: {
        count() {
           return store.state.count
        }
    },
    methods: {
        add() {
           //传参
           store.commit('increment',10) 
        }
    }
})

2、具体到项目中,用mapMutations辅助函数的传参

  • 新建一个store.js文件
//store.js
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

//定义state,并将listName设置为一个空对象
const state = {
    listName: {}
}
//定义mutations,可以传参,用于设置state里的listName
const mutations = {
    set_listname: (state,value) => {
        state.listName=value
    }
}
//定义getters,用于获取出state里的对象
const getters = {
    get_listname: state => {
        return state.listName
    }
}

export default new Vuex.Store({
    getters,
    state,
    mutations
})
  • 在vue实例中注册store
//main.js
import Vue from 'vue'
import App from './App'
import store from './store'

/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  store,
  template: '<App/>',
  components: { App }
})
  • 在App.vue组件中使用mapMutations传参,修改state数据(状态)
    要点: 要写在methods下面,因为mapActions/mapMutations只是把action/mutation函数绑定到你的methods里了;你调methods里的方法的时候照常传参就可以了。
//App.vue
import {mapMutations} from 'vuex'

export default {
  //定义一个listName,作为下面的mapMutations的传参参数,修改state的listName
  data() {
    listName: {
      name:'Ewall',
      age:'21'
    }
  },
  created (){
    //调用set_listname方法,将listName对象作为参数传入
    this.set_listname(listName)
  },
  methods: {
    ...mapMutations(['set_listname'])
  },
  
}
  • 再定义一个子组件,获取state对象里面的数据
//app-child.vue
 import {mapGetters} from 'vuex'

  export default {
      computed: {
      //获取state里面的listName对象
          ...mapGetters(['get_listname'])
      },
      created() {
      //打印下获得数据结果
          console.log(this.get_listname)
      }
  }

参考: https://vuex.vuejs.org/zh-cn/mutations.html

目录
相关文章
|
5月前
|
存储 JavaScript
vue sessionStorage存值取值问题
vue sessionStorage存值取值问题
70 1
|
6月前
|
存储 JavaScript 容器
Vuex的简介,存值取值的介绍以及异步请求
Vuex的简介,存值取值的介绍以及异步请求
|
6月前
|
存储 缓存 JavaScript
Vuex存值取值与异步请求处理
Vuex存值取值与异步请求处理
76 0
|
6月前
|
存储 JavaScript 前端开发
Vuex基础使用存取值+异步请求
Vuex基础使用存取值+异步请求
33 1
|
5月前
|
JavaScript 网络架构 开发者
Vue 路由传参和获取参数的方法
Vue 路由传参和获取参数的方法
174 1
|
1月前
|
JavaScript
Vue路由传参的几种方式详解
vue-router传递参数分为两大类: >编程式的导航 router.push 声明式的导航 <router-link>
|
8月前
|
JavaScript
Vue 中组件中传参数,传函数
Vue 中组件中传参数,传函数
50 0
|
4月前
|
存储 缓存
uniapp存值和取值方法
uniapp存值和取值方法
57 0
|
4月前
|
JavaScript 网络架构
Vue 路由器传参和取值 路径参数
Vue 路由器传参和取值 路径参数
|
5月前
|
JSON JavaScript 数据格式
Vue3.0实现todolist之路由传参(query模式传参和params传参)
Vue3.0实现todolist之路由传参(query模式传参和params传参)
39 1