我對vuex的理解(二) 之 mapGetters取值和mapMutations的傳參

前言:最近在做一個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

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • Vuex是什么? Vuex 是一個專為 Vue.js應用程序開發的狀態管理模式。它采用集中式存儲管理應用的所有組件...
    蕭玄辭閱讀 3,138評論 0 6
  • 安裝 npm npm install vuex --save 在一個模塊化的打包系統中,您必須顯式地通過Vue.u...
    蕭玄辭閱讀 2,963評論 0 7
  • Vuex 是一個專為 Vue.js 應用程序開發的狀態管理模式。它采用集中式存儲管理應用的所有組件的狀態,并以相應...
    白水螺絲閱讀 4,684評論 7 61
  • Vuex 的學習記錄 資料參考網址Vuex中文官網Vuex項目結構示例 -- 購物車Vuex 通俗版教程Nuxt....
    流云012閱讀 1,472評論 0 7
  • vuex是什么鬼? 如果你用過redux就能很快的理解vuex是個什么鬼東西了。他是vuejs用來管理狀態的插件。...
    麥子_FE閱讀 6,890評論 3 37