在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>
相关推荐
weixin_395448912 小时前
main.c_cursor_0202
前端·网络·算法
摘星编程2 小时前
用React Native开发OpenHarmony应用:Calendar日期范围选择
javascript·react native·react.js
东东5162 小时前
基于vue的电商购物网站vue +ssm
java·前端·javascript·vue.js·毕业设计·毕设
MediaTea3 小时前
<span class=“js_title_inner“>Python:实例对象</span>
开发语言·前端·javascript·python·ecmascript
雨季6663 小时前
Flutter 三端应用实战:OpenHarmony “微光笔记”——在灵感消逝前,为思想点一盏灯
开发语言·javascript·flutter·ui·dart
编码者卢布3 小时前
【Azure Stream Analytic】用 JavaScript UDF 解决 JSON 字段被转成 Record 的关键点
javascript·json·azure
梦梦代码精3 小时前
开源、免费、可商用:BuildingAI一站式体验报告
开发语言·前端·数据结构·人工智能·后端·开源·知识图谱
松树戈3 小时前
滥用AI生图引起的JavaScript heap out of memory排查记录
vue.js·ai编程
0思必得03 小时前
[Web自动化] Selenium执行JavaScript语句
前端·javascript·爬虫·python·selenium·自动化