uniapp vuex 搭建

1.index.js

javascript 复制代码
import user from './modules/user.js'

import {
	createStore
} from 'vuex'
// todo ssr
const store = createStore({
	modules: {
		user,
	}
})

export default store

2.user.js

javascript 复制代码
export default {
    namespaced: true,
    state: {
		token:"", //token
		userId:"", //用户id
		userName:"",//用户姓名
	},
    mutations: {
		SET_TOKEN(state,token){
			state.token = token
			uni.setStorageSync("token",token)
		},
		LOGIN_OUT(state){
			state.token = ""
			uni.removeStorageSync("token")
			//uni.clearStorageSync()
			uni.reLaunch({
				url:"/pages/index/index"
			})
		},
		SET_USERID(state,id){
			state.userId = id
			uni.setStorageSync("userId",id)
		},
		SET_USERNAME(state,name){
			state.userName = name
			uni.setStorageSync("userName",name)
		},
	},
    actions: {
		setToken({commit},token){
			commit("SET_TOKEN",token)
		},
		setUserId({commit},id){
			commit("SET_USERID",id)
		},
		loginOut({commit}){
			commit("LOGIN_OUT")
		},
	}
}

3.main.js

javascript 复制代码
import store from './store'
import { createSSRApp } from 'vue'
import App from './App.vue'
export function createApp() {
  const app = createSSRApp(App)
  app.use(store)
  return {
    app
  }
}
相关推荐
用户66982061129822 分钟前
js今日理解 blob和arrayBuffer 二进制数据
前端·javascript
青莲84310 分钟前
深拷贝 vs 浅拷贝
android
1024小神11 分钟前
Ant Design这个日期选择组件最大值最小值的坑
前端·javascript
一枚小小程序员哈23 分钟前
基于Android的音乐播放器/基于android studio的音乐系统/音乐管理系统
android·ide·android studio
安禅不必须山水1 小时前
Javascript函数里的this指向
javascript
叽哥1 小时前
flutter学习第 13 节:本地存储
android·flutter·ios
拉不动的猪1 小时前
移动端音频插件howler简单配置
前端·javascript·vue.js
Juchecar2 小时前
Node.js 项目 TypeScript + express 实现 Web 服务端返回文件内容
javascript
_一两风2 小时前
《告别回调地狱!三种写法带你玩转 JavaScript 异步》
javascript·ecmascript 6
林太白2 小时前
Rust-导入导出
前端·javascript·后端