1、使用 HBuilderX 创建一个 vue3的新项目
- 点击左上角的文件 --> 选择新建 --> 项目
3、查看当前项目的版本
data:image/s3,"s3://crabby-images/58c4e/58c4e5ca74d0a2cb6b037cc7bec9819c29d4f178" alt=""
4、把项目可以先跑起来----我这里是运行在谷歌浏览器 也可以运行在微信小程序开发者工具上
data:image/s3,"s3://crabby-images/aaf96/aaf9676b8c4d280fd192d836312d844c8399a18b" alt=""
5、看运行结果
data:image/s3,"s3://crabby-images/b11f6/b11f6969bdfe632371b4fcc3abf962e3b08acd24" alt=""
2、在项目中配置Pinia --> Pinia 官网---> 点击开始使用
- Pinia
data:image/s3,"s3://crabby-images/52bcf/52bcf85bc4ff781e9620c0236e045f5b79f12f3f" alt=""
2、 点击左侧的 开始 安装pinia
data:image/s3,"s3://crabby-images/fbc90/fbc907dd5c9c06134b49c2049a86b9c9f5140ac4" alt=""
3、可以在项目中使用终端安装 Pinia 也可以在编辑器中使用 终端安装pinia 我这使用的是 编辑中的终端进行安装的 如果用的 npm 命令可能会安装失败 出现的报错不同自己解决;使用yarn 是不会报错的
data:image/s3,"s3://crabby-images/dead5/dead5de2e3c79941cb43bf93521524f3a24ef77a" alt=""
4、安装成功之后 使用 yarn list pinia 可以查看pinia 有没有安装成功 出现 pinia@2.1.7说明安装成功
data:image/s3,"s3://crabby-images/cdfeb/cdfeb9b23c1bb02110913029bb57480c0b2fd1d1" alt=""
5、初始化pinia --> 在项目中的 main.js 中配置一下代码
data:image/s3,"s3://crabby-images/ccc5d/ccc5d832b3e2d3b9e2816b405f8c254ced2775c6" alt=""
6、定义 store 在项目中 新建一个目录 stores --> 再随便创建一个js文件 我这边创建一个 counter.js 文件
data:image/s3,"s3://crabby-images/157e2/157e292932ea03929e351cf465f538f3b69f5c5f" alt=""
data:image/s3,"s3://crabby-images/120ab/120abbf5f2ed296d61dc0dcf6ede49ccaac18a3d" alt=""
7、定义 store 我们这里用的是vue3 所以我们选择 setup store
data:image/s3,"s3://crabby-images/f88c9/f88c92930b6a95285ebc6b3360d6de6fe0493175" alt=""
data:image/s3,"s3://crabby-images/73858/7385828a39ed8df5f35b22b658bc8dc842fa2618" alt=""
8、使用store 在pages目录下 随便创建一个vue文件 然后把下面的这段代码粘过去
html
<script setup></script>
<template>
<view class="counter">
<button class="button" type="primary">-</button>
<input class="input" type="text"/>
<button class="button" type="primary" >+</button>
</view>
</template>
<style lang="scss" scoped>
.counter {
display: flex;
padding: 100rpx;
}
.input {
flex: 1;
height: 96rpx;
text-align: center;
border: 2rpx solid #eee;
box-sizing: border-box;
}
.button {
width: 100rpx;
margin: 0;
&:first-child {
border-start-end-radius: 0;
border-end-end-radius: 0;
}
&:last-child {
border-start-start-radius: 0;
border-end-start-radius: 0;
}
}
</style>
别忘了还要在 pages中配置一下当前的页面
data:image/s3,"s3://crabby-images/f7ff2/f7ff27069ded9e8d2f3603506c99cc858324fdcb" alt=""
9、在 script 中导入并打印
data:image/s3,"s3://crabby-images/08bcb/08bcb7fe59aa384c76dbf4ea2617ea58c95dfd15" alt=""
10、在stores 中定义两个方法
data:image/s3,"s3://crabby-images/26005/26005dc747d6a328e693fe200716da661c461445" alt=""
11、在pages中的pinia下的index中使用一下我们在store中定义好的方法
data:image/s3,"s3://crabby-images/366bb/366bbd4650782e1c7f84e619474e967090ea0a8a" alt=""
12、在浏览器上调到这个页面 就可以正常的 加加减减了
data:image/s3,"s3://crabby-images/3944c/3944c7b165faac8003e2ff70626c918d1737dc5c" alt=""
13、如果感觉麻烦的话 我们也可以使用 storeToRefs 解构数据 我这边就不做演示了
data:image/s3,"s3://crabby-images/0deb4/0deb4b230a42a73dec5d9f5004b820b55d95d2f8" alt=""
3、使用pinia中的 持久化存储数据
pinia-plugin-persistedstate
链接地址 http://快速开始 | pinia-plugin-persistedstate
data:image/s3,"s3://crabby-images/c87f5/c87f57be8c7f70e73af92975f816d42246a6adc9" alt=""
2、安装持久化插件 并且使用插件
data:image/s3,"s3://crabby-images/b6b9d/b6b9d291c2878cbfe47145c20ff61da9077da59b" alt=""
data:image/s3,"s3://crabby-images/5b6a0/5b6a0f46ffcf07ada357e519dcc7d7c3347186a1" alt=""
3、因为我们选的是 vue3 项目 所以我们使用 组合式
data:image/s3,"s3://crabby-images/99a10/99a10726bce3b3a5c11a888c6972fab436f8bb60" alt=""
4、在store中配置
data:image/s3,"s3://crabby-images/cd125/cd1252ec53f82dfcbe510c8e3788ec27573db023" alt=""
5、在浏览器中可以看到已经存储起来了
data:image/s3,"s3://crabby-images/1b25d/1b25d8780e17015f3784b1c88828dbed9b3f22fd" alt=""
6、使用进阶用法 修改持久化存储 的方法
data:image/s3,"s3://crabby-images/794c6/794c61d9e9fe14f0050e8784f6fe612dd17f1eab" alt=""
代码修改
javascript
// main.js
import {
createSSRApp
} from 'vue'
// 引入 Pinia
import {
createPinia
} from 'pinia'
// 持久化存储
// import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'
// 进阶用法
import {
createPersistedState
} from 'pinia-plugin-persistedstate'
import App from './App'
export function createApp() {
const app = createSSRApp(App)
// 实例化Pinia
const pinia = createPinia()
// 持久化
// pinia.use(piniaPluginPersistedstate)
// 进阶
pinia.use(
createPersistedState({
// 自定义
storage: {},
})
)
// 传递给项目应用
app.use(pinia)
return {
app
}
}
7、 点击下面的 store 或者 点击侧边栏的 配置 对store进行一个配置
data:image/s3,"s3://crabby-images/2b16f/2b16fca24ef3ee64e1fc628968210566a8194c5a" alt=""
8、可以在 main.js中配置 或者 在store中单独写一个文件进行配置
data:image/s3,"s3://crabby-images/1f39c/1f39c25dba926adbe3fc404d1fcf66b17051a30a" alt=""
单独配置
javascript
// stores/persist.js
import { createPersistedState } from 'pinia-plugin-persistedstate'
export const piniaPluginPersistedstate = createPersistedState({
key: (id) => `__persisted__${id}`,
storage: {
getItem: (key) => {
// h5: localStorage.getItem(key)
// mp: wx.getStorageSync(key)
return uni.getStorageSync(key)
},
setItem: (key, value) => {
// h5: localStorage.getItem(key,value)
// mp: wx.getStorageSync(key,value)
uni.setStorageSync(key, value)
},
},
})
javascript
import App from './App'
import './utils/utils.js'
import { createPinia } from 'pinia'
// import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'
import {piniaPluginPersistedstate} from '@/stores/persist.js'
// #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'
export function createApp() {
const app = createSSRApp(App)
const pinia = createPinia()
// pinia.use(piniaPluginPersistedstate)
pinia.use(piniaPluginPersistedstate)
app.use(pinia)
return {
app,
}
}
// #endif
9、细节
data:image/s3,"s3://crabby-images/6aed6/6aed66caa67fe00427c47a744870942268e5dd42" alt=""