关键词搜索

全站搜索
×
密码登录在这里
×
注册会员
×

已有账号? 请点击

忘记密码

已有账号? 请点击

使用其他方式登录

vue中vuex模块化使用详细讲解mapState等详细讲解

发布2022-03-07 浏览1091次

详情内容

在vue中使用vuex,很多人看了很我遍官方不太明白,现在从基本用法及模块化使用详细讲解怎么在项目整合使用。以及mapState、mapMutations、mapActions、mapGetters使用方法。看完整个文章保证让你全使用vux。

文件目录结构和文件代码

image.png

image.png

index.js文件

import Vue from 'vue'
import Vuex from 'vuex'

import moduleA from './modules/moduleA'
import moduleB from './modules/moduleB'

Vue.use(Vuex)

export default new Vuex.Store({
	modules: {
		moduleA,
		moduleB
	},
	state: {
		"indexName": "名字",
		"indexFirstName": "主要第一名字",
		"indexLastName": "主要最后名字",
		"indexUser": {
			"userName": "主要人员名称",
			"age": 18
		}
	},
	getters: {
		allName: state => {
			return state.indexFirstName + state.indexLastName
		}
	},
	mutations: {
		SET_INDEX_NAME: (state, name) => {
			state.indexName = name
		},
	},
	actions: {
		changeName(context, newName) {
			context.commit("SET_INDEX_NAME", newName)
		}
	}
})

moduleA.js文件

export default {
	namespaced: true,
	state: {
		aName: "moduleA的名字",
		aNum: 1
	},
	getters: {
		aGetterName: state => {
			return state.aName + "aGetterName"
		}
	},
	mutations: {
		ADD_ANUM(state, num) {
			state.aNum = state.aNum + num
		}
	},
	actions: {
		addCountAction(context, num) {
			context.commit('ADD_ANUM', num)
		}
	}
}

一、基本用法

state属性:基本数据;
getters属性:从 state 中派生出的数据;
mutation属性:更新 store 中数据的唯一途径,其接收一个以 state 为第一参数的回调函数;
action 属性:提交 mutation 以更改 state,其中可以包含异步操作;
module 属性:用于将 store分割成不同的模块。

// 获取index的数据   state      getters
console.log("indexName", this.$store.state.indexName)
console.log("indexUser", this.$store.state.indexUser)

console.log("allName", this.$store.getters.allName)

// 修改index的数据   mutations  actions
this.$store.commit('SET_INDEX_NAME', "修改主要名字")
console.log("indexName", this.$store.state.indexName)

this.$store.dispatch("changeName", "再次修改主要名字")
console.log("indexName", this.$store.state.indexName)

打印结果

image.png


二、模块化

// 获取moduleA的数据   state      getters
console.log("moduleA  aName", this.$store.state.moduleA.aName)
console.log("moduleA  aNum", this.$store.state.moduleA.aNum)

console.log("moduleA  aGetterName", this.$store.getters['moduleA/aGetterName'])

// 修改moduleA的数据   mutations  actions
this.$store.commit('moduleA/ADD_ANUM', 10);
console.log("moduleA  aNum", this.$store.state.moduleA.aNum)

this.$store.dispatch('moduleA/addCountAction', 10)
console.log("moduleA  aNum", this.$store.state.moduleA.aNum)

打印结果

image.png


三、mapState、mapMutations、mapActions、mapGetters具体用法

mapState辅助函数用法

import { mapState } from 'vuex'
export default {
  computed: {
    // ...mapState(["indexName", "indexUser"])
    ...mapState({
      newIndexName: "indexName",
      newIndexUser: "indexUser",
      // 模块化使用方式
      newAName: state => state.moduleA.aName,
    })
  },
  created () {
    this.init()
  },
  methods: {
    init () {
      // console.log('indexName', this.indexName)
      // console.log('indexUser', this.indexUser)
      console.log('newIndexName', this.newIndexName)
      console.log('newIndexUser', this.newIndexUser)
      console.log('newAName', this.newAName)
    }
  },
}

mapGetters

import { mapGetters } from 'vuex'
export default {
  computed: {
    ...mapGetters({
      newAllName: "allName",
    }),
    ...mapGetters('moduleA', {
      newAGetterName: "aGetterName",
    }),
  },
  created () {
    this.init()
  },
  methods: {
    init () {
      console.log('newAllName', this.newAllName)
      console.log('newAGetterName', this.newAGetterName)
    }
  },
}

mapMutations

image.png

import { mapMutations } from 'vuex'
export default {
  methods: {
    ...mapMutations({
      setIndexName: "SET_INDEX_NAME"
    }),
    ...mapMutations('moduleA', {
      addAnum: "ADD_ANUM"
    }),
    changeIndexName (val) {
      this.setIndexName(val)
      console.log('indexName', this.$store.state.indexName)
    },
    changeAnum () {
      this.addAnum(100)
      console.log('indexName', this.$store.state.moduleA.aNum)
    },
  },
}

mapActions

image.png

import { mapActions } from 'vuex'
export default {
  methods: {
    ...mapActions({
      changeName: "changeName"
    }),
    ...mapActions('moduleA', {
      addCountAction: "addCountAction"
    }),
    changeNameBtn () {
      this.changeName("再次变更主要姓名")
      console.log('indexName', this.$store.state.indexName)
    },
    addCountActionBtn () {
      this.addCountAction(210)
      console.log('indexName', this.$store.state.moduleA.aNum)
    },
  },
}

四、表单处理(v-model)

image.png

computed: {
  message: {
    get () {
      return this.$store.state.obj.message
    },
    set (value) {
      this.$store.commit('updateMessage', value)
    }
  }
}


点击QQ咨询
开通会员
返回顶部
×
  • 微信支付
微信扫码支付
微信扫码支付
请使用微信描二维码支付
×

提示信息

×

选择支付方式

  • 微信支付
确定支付下载