Pinia+Router学习笔记(五)

简介: 本节记录例API和Pinia持久化插件相关内容

例API存在于通过pinia导出的函数调用后的返回值中,主要有以下几种:

$reset 重置store到其初始状态
$subscribe 当state中的数据发生变化时调用,接收一个回调函数,其中有args和state两个参数
$onAction 当actions被调用时会执行这个函数,接收一个回调函数,有一个args参数

Pinia持久化插件:

import { createApp,toRaw } from 'vue'
// import './style.css'
import App from './App.vue'
// import ElementPlus from 'element-plus'
// import 'element-plus/dist/index.css'
// import './css/index.css'
import { createPinia, PiniaPluginContext } from 'pinia'

export const app = createApp(App)

// app.use(ElementPlus)

type Options = {
    key?: string
}

// 定义兜底变量,如果用户没有传key则默认key为'xiaoman'
const __piniaKey__: string = 'xiaoman'

// 在localsession中存储键值对
const setStorage = (key: string, value: any) => {
    localStorage.setItem(key, JSON.stringify(value))
}

// 定义取内容的函数
const getData = (key:string) => {
    return localStorage.getItem(key) ? JSON.parse(localStorage.getItem(key) as string) : {}
}

// 利用函数柯里化使key能够被传入
const piniaPlugin = (option: Options) => {
    return (context: PiniaPluginContext) => {
        const { store } = context
        // 将数据取出并返回给state,使页面上的内容发生变化(store.$id是每个store的唯一标识符)
        const data = getData(`${option?.key ?? __piniaKey__}-${store.$id}`)
        store.$subscribe(() => {
            // 由于store.$state是一个proxy对象,因此通过toRaw使其成为一个原始对象
      // 如果没有传入key则默认为兜底变量xiaoman(??是空置合并运算符)
            setStorage(`${option?.key ?? __piniaKey__}-${store.$id}`, toRaw(store.$state))
        })
        return {
            ...data
        }
    }
}

const store = createPinia()

store.use(
    piniaPlugin({
        key: 'pinia',
    })
)

app.use(store)

app.mount('#app')

至此,pinia完结

相关文章
|
5月前
|
移动开发 资源调度 前端开发
React Router V6 useRoutes的使用
【8月更文挑战第29天】 React Router V6 useRoutes的使用
226 3
|
5月前
|
前端开发 JavaScript UED
什么是 React Router?
【8月更文挑战第31天】
33 0
|
8月前
|
JavaScript
|
缓存 JavaScript
Vue Router 学习 new Router
Vue Router 学习 new Router
151 0
|
8月前
|
缓存 移动开发 JavaScript
【学习笔记】Vue Router
【学习笔记】Vue Router
68 0
|
8月前
|
存储 资源调度 前端开发
React Router v6 完全指南(上)
React Router v6 完全指南(上)
397 0
|
存储
Pinia+Router学习笔记(六)
从本节开始进入Router学习,先介绍下Vue-Router的基本配置
89 0
|
JavaScript API
Pinia+Router学习笔记(八)
本节记录Vue中命名路由-编程式导航相关内容
225 0
Pinia+Router学习笔记(三)
本节记录解构Store过程中的相关操作及注意事项
101 0
|
前端开发 中间件 SEO
Pinia+Router学习笔记(七)
本节介绍Vue-Router的两种路由模式
97 0

热门文章

最新文章