UniApp+Vue3引入Pinia的案例(小白通吃)

第一步:使用HBuilder创建项目 UniApp+Vue3项目

选择Vue3版本

第二步:创建完成之后创建Store目录

创建store目录创建store下的modules目录

store目录下有一个index.js文件是所有子模块的出口,主要模块都在modules里面,跟着创建就行

store/index.js代码

注意:UniApp+Vue3中自带pinia不需要进行下载pinia了

不过需要下载一下持久化插件 pinia持久化插件官网

javascript 复制代码
npm i pinia-plugin-persistedstate
javascript 复制代码
// 引入pinia
import { createPinia } from "pinia"

// 引入pinia持久化插件
import persist from "pinia-plugin-persistedstate"

// 实例化pinia
const pinia = createPinia()

// 使用persist插件
pinia.use(persist)

// 导出pinia引入main.js使用
export default pinia;

// 导出所有子模块中的数据
export * from "./modules"

store/modules/index.js文件中的代码

javascript 复制代码
// 引入pinia方法
import {defineStore} from "pinia"
// 引入 ref
import { ref } from "vue"
// 定义一个store	
export const indexInfo = defineStore('index',()=>{
	// 定义一个数据信息
	const info = ref("")
	// 为数据赋值
	const setInfo =(value)=>{
		info.value = value
	}
	// 返回数据方法
	return{
		info,
		setInfo
	}
},{
	// 配置持久化信息     //由于小程序与网页使用的方法不同这里要配置一下
	persist:{
		storage:{
			getItem:uni.getStorageSync,
			setItem:uni.setStorageSync
		}
	}
})

第四步:引入main.js中,挂载到全局

javascript 复制代码
import App from './App'
// #ifndef VUE3

import Vue from 'vue'
import './uni.promisify.adaptor'
Vue.config.productionTip = false
App.mpType = 'app'
const app = new Vue({
  ...App
})
app.$mount()
// #endif

// #ifdef VUE3
import { createSSRApp } from 'vue'
// 引入主Store
import pinia from "./store/index.js"
export function createApp() {
  const app = createSSRApp(App)
  // 挂载到实例
  app.use(pinia)
  return {
    app
  }
}
// #endif

第五步:在某个组件中使用

javascript 复制代码
<template>
	<view class="content">
		<!-- 数据展示 -->
		{{info.info}}
	</view>
</template>

<script setup>
	// 引入
import { indexInfo } from '../../store';
const info = indexInfo()
// 随便测试
info.setInfo(123123123213)

</script>

完美收工

相关推荐
Moment18 分钟前
Agent 开发本质上就是高级点的 CRUD
前端·后端·面试
恋猫de小郭42 分钟前
OpenAI 亲自教你如何构建可靠 AI 代码,从古法编程转向 Agnet 编程,或者 PUA 你的 AI
前端·人工智能·ai编程
程序员爱钓鱼2 小时前
Go错误处理全解析:errors包实战与最佳实践
前端·后端·go
清汤饺子10 小时前
OpenClaw 本地部署教程 - 从 0 到 1 跑通你的第一只龙虾
前端·javascript·vibecoding
爱吃的小肥羊12 小时前
比 Claude Code 便宜一半!Codex 国内部署使用教程,三种方法任选一!
前端
IT_陈寒13 小时前
SpringBoot项目启动慢?5个技巧让你的应用秒级响应!
前端·人工智能·后端
树上有只程序猿14 小时前
2026低代码选型指南,主流低代码开发平台排名出炉
前端·后端
橙某人14 小时前
LogicFlow 小地图性能优化:从「实时克隆」到「占位缩略块」!🚀
前端·javascript·vue.js
高端章鱼哥14 小时前
为什么说用OpenClaw对打工人来说“不划算”
前端·后端
大脸怪14 小时前
告别 F12!前端开发者必备:一键管理 localStorage / Cookie / SessionStorage 神器
前端·后端·浏览器