uniapp使用vuex

  1. 项目根目录创建store文件夹,store创建index.js文件
  2. store里的index.js文件引入vue,vuex,导出vuex.store
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
export default new Vuex.Store({})

store对象结构
2.1 :state

//全局属性变量
	state:{
		num:0,
		price:10,
		name:'苹果',
		dataArray:[]
	},

2.2:mutations

//全局同步方法 通过this.$store.commit('xxx')调用
	mutations:{
		add(state){
			state.num++
			console.log(state.num)
		}
	},

2.3:getters

//Vuex属性计算,在视图里当做变量使用
	getters:{  //getters里面函数的执行要依赖一个可变的变量
		count(state){  
			return state.price*state.num
		}
	},

2.4:actions

//全局异步方法 通过this.$store.dispatch('xxx')调用
	actions:{
		dataArray(context){  //context:上下文 里面包含了state mutations getters actions
			setTimeout(function(){
				context.state.dataArray = ['美短','英短','蓝猫','银渐层']
			},2000)
		}
	}

3.main.js引入vuex并设入vue原型

import store from './store/index.js' //引入vuex
Vue.prototype.$store = store //将vuex设置入vue的原型

然后页面就可以通过this.$store来访问vuex属性方法

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值