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

前言:最近在做一個vue的項目悦即,碰到一點關(guān)于mapMutations傳參的問題斤斧,解決完問題了所以寫一下對它理解厚宰。

1到踏、官網(wǎng)中的提交載荷(傳參)具體到一般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輔助函數(shù)的傳參

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

Vue.use(Vuex)

//定義state智绸,并將listName設(shè)置為一個空對象
const state = {
    listName: {}
}
//定義mutations,可以傳參砸紊,用于設(shè)置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數(shù)據(jù)(狀態(tài))
    要點: 要寫在methods下面醉顽,因為mapActions/mapMutations只是把action/mutation函數(shù)綁定到你的methods里了;你調(diào)methods里的方法的時候照常傳參就可以了。
//App.vue
import {mapMutations} from 'vuex'

export default {
  //定義一個listName平挑,作為下面的mapMutations的傳參參數(shù)游添,修改state的listName
  data() {
    listName: {
      name:'Ewall',
      age:'21'
    }
  },
  created (){
    //調(diào)用set_listname方法,將listName對象作為參數(shù)傳入
    this.set_listname(listName)
  },
  methods: {
    ...mapMutations(['set_listname'])
  }
}
  • 再定義一個子組件通熄,獲取state對象里面的數(shù)據(jù)
 //app-child.vue
 import {mapGetters} from 'vuex'

  export default {
      computed: {
      //獲取state里面的listName對象
          ...mapGetters(['get_listname'])
      },
      created() {
      //打印下獲得數(shù)據(jù)結(jié)果
          console.log(this.get_listname)
      }
  }

參考學(xué)習(xí)
https://vuex.vuejs.org/zh-cn/mutations.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末唆涝,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子唇辨,更是在濱河造成了極大的恐慌廊酣,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件赏枚,死亡現(xiàn)場離奇詭異亡驰,居然都是意外死亡,警方通過查閱死者的電腦和手機饿幅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進店門凡辱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人栗恩,你說我怎么就攤上這事透乾。” “怎么了?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵乳乌,是天一觀的道長捧韵。 經(jīng)常有香客問我,道長汉操,這世上最難降的妖魔是什么纫版? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮客情,結(jié)果婚禮上其弊,老公的妹妹穿的比我還像新娘。我一直安慰自己膀斋,他們只是感情好梭伐,可當(dāng)我...
    茶點故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著仰担,像睡著了一般糊识。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上摔蓝,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天赂苗,我揣著相機與錄音,去河邊找鬼贮尉。 笑死拌滋,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的猜谚。 我是一名探鬼主播败砂,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼魏铅!你這毒婦竟也來了昌犹?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤览芳,失蹤者是張志新(化名)和其女友劉穎斜姥,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體沧竟,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡铸敏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了屯仗。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片搞坝。...
    茶點故事閱讀 38,100評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖魁袜,靈堂內(nèi)的尸體忽然破棺而出桩撮,到底是詐尸還是另有隱情敦第,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布店量,位于F島的核電站芜果,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏融师。R本人自食惡果不足惜右钾,卻給世界環(huán)境...
    茶點故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望旱爆。 院中可真熱鬧舀射,春花似錦、人聲如沸怀伦。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽房待。三九已至邢羔,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間桑孩,已是汗流浹背拜鹤。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留流椒,地道東北人敏簿。 一個月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像镣隶,于是被迫代替她去往敵國和親极谊。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,834評論 2 345

推薦閱讀更多精彩內(nèi)容

  • Vuex是什么安岂? Vuex 是一個專為 Vue.js應(yīng)用程序開發(fā)的狀態(tài)管理模式。它采用集中式存儲管理應(yīng)用的所有組件...
    蕭玄辭閱讀 3,106評論 0 6
  • 安裝 npm npm install vuex --save 在一個模塊化的打包系統(tǒng)中帆吻,您必須顯式地通過Vue.u...
    蕭玄辭閱讀 2,926評論 0 7
  • Vuex 是一個專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式域那。它采用集中式存儲管理應(yīng)用的所有組件的狀態(tài),并以相應(yīng)...
    白水螺絲閱讀 4,652評論 7 61
  • Vuex 的學(xué)習(xí)記錄 資料參考網(wǎng)址Vuex中文官網(wǎng)Vuex項目結(jié)構(gòu)示例 -- 購物車Vuex 通俗版教程Nuxt....
    流云012閱讀 1,451評論 0 7
  • vuex是什么鬼猜煮? 如果你用過redux就能很快的理解vuex是個什么鬼東西了次员。他是vuejs用來管理狀態(tài)的插件。...
    麥子_FE閱讀 6,856評論 3 37