Vuex笔记

基于vuex官方文档提供的模块化和命名空间的文件结构,进行开发页面级别调用vuex中状态和方法如下:

(1)获取vuex中的状态属性

//1.路由数据routerList放到了vuex进行管理,对于routerList数据的获取请求也写到了vuex中
<template>
</template>
<script>
import { mapState,mapMutations,mapGetters,,mapActions } from "vuex"
export default {
	name:'',
	data(){},
	computed:{
		...mapState({
			routerList:(state)=>state.menuList.routerList,//注意在使用了命名空间情况下,要在对应的属性名前写上模块名,没有开启命名空间时(该属性默认为vuex的全局属性),直接忽略前边的模块名menuList即可
		}),
		...mapGetters({
			getCache: "formCache/getCache",
		})
	},
	methods:{
	}
	
}
</script>

(2)想要调用vuex中的方法时

//和案例一中一样:引入mapMutation映射方法后,直接将对应模块下的vue方法映射为当前组件的方法,这样就可以直接在当前页面中当成普通方法调用
methods:{
	...mapActions({
		getCurrentDateHttp:"data/getCurrentDateHttp",
	}),
	...mapMutations({
         setTaskListActive:'task/setTaskListActive'
     })
}

需求demo:
1.在单页面中使用的数据是全局存储管理的。

1)对应Vuex的模块中定义相关state,getter、mutation、action
(2)页面调用
方式一:通过全局Vue实例拿到触发
this.$store.state.xxxMoudle.xxxState
this.$store.getters['xxxMoudle/xxxGetter']
this.$store.commit('xxxMoudle/xxxMutation',{age:"22"});
this.$store.dispatch('xxxMoudle/xxxAction',{name:"ddd"});
方式二:使用vuex提供的辅助函数(全家福写法)
import {mapState,mapGetters,mapMutations,mapActions} from 'vuex'
export deafult{
	computed:{
		...mapState({
			currentData:state=>state.app.data,
			currentCount:state=>state.app.count,
		}),
		...mapGetters({
			user:"getUserInfo",
		})
	},
	methods:{
		...mapMutations({
			currentMethod:"xxxMoudle/xxxMutation",
		}),
		...mapActions({
			currentMethod2:"xxxMoudle/xxxAction",
		})
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值