第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

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

標(biāo)簽:
Vue.js

前言:最近在做一个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.jsimport Vue from 'vue'import Vuex from 'vuex'Vue.use(Vuex)//定义state,并将listName设置为一个空对象const state = {    listName: {}
}//定义mutations,可以传参,用于设置state里的listNameconst 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.jsimport 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.vueimport {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)
      }
  }



作者:Ewall_
链接:https://www.jianshu.com/p/506da488d2a1


點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消