| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 | import Vue from 'vue'import Vuex from 'vuex'// import {request} from '@/common/js/request'import { getUserInfo } from '@/api/member/userProfile.js'Vue.use(Vuex)const store = new Vuex.Store({	state: {		openExamine: false, // 是否开启审核状态。用于小程序、App 等审核时,关闭部分功能。TODO 芋艿:暂时没找到刷新的地方		token: '', // 用户身份 Token		userInfo: {}, // 用户基本信息		timerIdent: false, // 全局 1s 定时器,只在全局开启一个,所有需要定时执行的任务监听该值即可,无需额外开启 TODO 芋艿:需要看看	},	getters: {		hasLogin(state){			return !!state.token;		}	},	mutations: {		// 更新 state 的通用方法		setStateAttr(state, param) {			if (param instanceof Array) {				for(let item of param){					state[item.key] = item.val;				}			} else {				state[param.key] = param.val;			}		},		// 更新token		setToken(state, data) {			// 设置 Token			const { token } = data;			state.token = token;			uni.setStorageSync('token', token);						// 加载用户信息			this.dispatch('obtainUserInfo');		},		// 退出登录		logout(state) {			// 清空 Token			state.token = '';			uni.removeStorageSync('token');			// 清空用户信息 TODO 芋艿:这里 setTimeout 的原因是,上面可能还有一些 request 请求。后续得优化下			setTimeout(()=>{				state.userInfo = {};			}, 1100)		},	},	actions: {		// 获得用户基本信息		async obtainUserInfo({state, commit}) {			const data = await getUserInfo();			commit('setStateAttr', {				key: 'userInfo',				val: data			});		}	}}) export default store
 |