vue Pinia 状态管理库

Pinia 是 Vue 的专属状态管理库,它允许你跨组件或页面共享状态。与 Vuex 相比,Pinia 不仅提供了一个更简单的 API,也提供了符合组合式 API 风格的 API,最重要的是,搭配 TypeScript 一起使用时有非常可靠的类型推断支持。今天主要记录一下在Vue3下使用Pinia的使用情况:

一、安装

yarn add pinia

或者

npm install pinia

二、创建Pinia

复制代码
import { createApp } from 'vue'
import App from './App.vue'
import { createPinia } from 'pinia'

const pinia = createPinia()

createApp(App).use(pinia).mount('#app')

三、定义属性和方法

TypeScript 复制代码
import { defineStore } from 'pinia'

export const useTemplate = defineStore('useTemplate',{
    state:() => ({
        count:0
    }),
    getters:{
        doubleCount:(state) =>{
            state.count * 2
        },
        threeCount:(state) => state.count * 3
    },
    actions:{
        addCount(){
            this.count ++
        },
        minusCount(){
            this.count --
        }
    }
})

在state中定义属性,和data类似,getters是定义计算属性,和computed类似,actions定义方法,和methods类似,所以上面的例子也可换种写法:

TypeScript 复制代码
export const useTemplate = defineStore('useTemplate',() =>{
    const count = ref(0)
    const doubleCount = computed(() => count1.value * 2)
    const threeCount = computed(() => count1.value * 3)
    function addCount(){
        count1.value ++
    }
    const minusCount = () =>{
        count1.value --
    }
    return {count,doubleCount,threeCount,addCount,minusCount}
})

四、使用

import { useTemplate} from '@/stores/useStores'

TypeScript 复制代码
import { useTemplate,useTemplate2 } from '@/stores/useStores'

const store = useTemplate()

//修改属性值
//方法1
store.count += 1
//方法2
store.addCount()
//方法3,重置属性值
store.$reset()

以上就是pinia的简单使用方法,更多复杂的,比如在actions中调用接口,万变不离其宗,都可以根据这种简单的例子来实现

相关推荐
lichenyang45313 小时前
Docker 学习笔记(一):为什么需要镜像、容器和仓库?
前端
kyriewen13 小时前
别再对着 TypeScript 报错发呆了:我把 10 个最常见的红色波浪线翻译成了人话
前端·javascript·typescript
IT_陈寒13 小时前
SpringBoot自动配置的坑,我的API突然就404了
前端·人工智能·后端
奇奇怪怪的14 小时前
Embedding 模型 10+ 横向评测
前端
陈广亮14 小时前
Monorepo 从 0 到 1 实操指南 2026 版:pnpm catalogs + Turborepo 2.x + changesets 全链路
前端
子兮曰14 小时前
OpenMontage 深度解剖:你的 AI 编程助手,其实是个视频工作室
前端·后端·ai编程
敲代码的鱼14 小时前
PDF 预览与签名批注写回 支持安卓 iOS 鸿蒙 UTS插件
android·前端·ios
子兮曰14 小时前
前端工具链的「Rust 化」:一场没有赢家的军备竞赛?
前端·后端·rust
Hyyy15 小时前
Function Calling / Tool Use的原理和实现模式
前端·llm·ai编程