在Vue3和TypeScripts中使用pinia

定义(state 是 store 的数据 (data),getters 是 store 的计算属性 (computed),而 actions 则是方法 (methods))

TypeScript 复制代码
// 引入pinia 和 vue
import { defineStore } from 'pinia'
import { ref, computed } from 'vue';
// 定义了一个名为 counter 的 store
export const useStore = defineStore('counter', ()=> {
    // 定义
    const count = ref(0)
    const userName = ref('')

    // Getter(计算属性)------ 只读
    const upperName = computed(() => userName.value.toUpperCase())
    // Action ------ 修改状态的方法
    function increment() {
        count.value++
    }

    function setUserName(name) {
        userName.value = name
    }
    
    
    // 重置函数
    function $reset() {
        count.value = 0
    }
    // 必须 return 所有要暴露的内容
    return {
        count,
        userName,
        increment,
        setUserName,
        $reset
    }
}

在组件中调用

TypeScript 复制代码
<template>
  <p>Count: {{ store.count }}</p>
  <p>Upper Name: {{ store.upperName }}</p>
  <button @click="store.increment">+1</button>
</template>

<script setup>
import { useCounterStore } from '@/stores/counter'

const store = useCounterStore()

// 调用 action
store.increment()
store.setUserName('Alice')

// 读取 state 或 getter(像属性一样访问)
console.log(store.count)       // 1
console.log(store.upperName)   // "ALICE"
</script>
相关推荐
锦木烁光3 分钟前
多端项目太乱?我是这样用 Monorepo 重构的
前端·架构
早點睡3903 分钟前
ReactNative项目OpenHarmony三方库集成实战:react-native-shadow-2
javascript·react native·react.js
上山打牛7 分钟前
cornerstone3D基本使用
前端
阿鑫_9967 分钟前
通用-Nvm基础知识
前端
xinzheng新政13 分钟前
Javascript·深入学习基础知识
前端·javascript·学习
前端付豪32 分钟前
实现记忆开关
前端·后端
前端开发呀36 分钟前
约定式路由的极简主义实践:一个插件搞定 React/Vue × Vite/Rspack
前端
代码煮茶37 分钟前
Vue3 插件开发实战 | 从 0 开发一个全局通知组件(Toast/Message)并发布到 npm
javascript·vue.js
程序员Ctrl喵42 分钟前
Flutter 第三阶段:基础 Widget 全面指南
开发语言·javascript·flutter
我就是马云飞42 分钟前
停更5年后,我为什么重新开始写技术内容了
android·前端·程序员