uniapp vue3 使用 pinia

javascript 复制代码
npm i pinia
npm install pinia pinia-plugin-persistedstate
javascript 复制代码
// main.js
import { createPinia } from 'pinia';
import piniaPluginPersistedstate from 'pinia-plugin-persistedstate';

export function createApp() {
	const app = createSSRApp(App)
	const pinia = createPinia()
	pinia.use(piniaPluginPersistedstate)
	app.use(pinia)
	return {
		app
	}
}

持久化:

javascript 复制代码
import {
	ref
} from 'vue';
import {
	defineStore
} from 'pinia';

export const useAuthStore = defineStore('auth', () => {
	const avatar = ref('');
	const mobile = ref('');
	const name = ref('');
	const token = ref('');

	const login = (userData) => {
		avatar.value = userData.avatar;
		mobile.value = userData.mobile;
		name.value = userData.name;
		token.value = userData.token;
	}

	return {
		avatar,
		mobile,
		name,
		token,
		login
	}
}, {
	persist: {
		key: 'userInfo',
		storage: {
			getItem: (key) => uni.getStorageSync(key),
			setItem: (key, value) => uni.setStorageSync(key, value),
		},
		paths: ['avatar', 'mobile', 'name', 'token'] // 明确指定要缓存的字段
	}
})

组件中使用:

javascript 复制代码
import { useAuthStore } from '@/stores/useAuthStore';

// 缓存用户登录信息
const userInfo = {
	avatar: member_head,
	mobile: member_mobile,
	name: member_name,
	token: member_token
}
const authStore = useAuthStore()
authStore.login(userInfo)
相关推荐
北冥有一鲲8 分钟前
LangChain.js:Tool、Memory 与 Agent 的深度解析与实战
开发语言·javascript·langchain
霁月的小屋21 分钟前
Vue响应式数据全解析:从Vue2到Vue3,ref与reactive的实战指南
前端·javascript·vue.js
小林rush39 分钟前
uni-app跨分包自定义组件引用解决方案
前端·javascript·vue.js
我的一行39 分钟前
已有项目,接入pnpm + turbo
前端·vue.js
亮子AI40 分钟前
【Svelte】怎样实现一个图片上传功能?
开发语言·前端·javascript·svelte
心.c41 分钟前
为什么在 Vue 3 中 uni.createCanvasContext 画不出图?
前端·javascript·vue.js
咸鱼加辣43 分钟前
【vue面试】ref和reactive
前端·javascript·vue.js
用户841794814561 小时前
vxe-table 导入 excel xlsx 时,单元格内容值丢失前面0解决方法
vue.js
KLW751 小时前
vue2 与vue3 中v-model的区别
前端·javascript·vue.js
李广山Samuel1 小时前
Node-OPCUA 入门(1)-创建一个简单的OPC UA服务器
javascript