【Vue3】Pinia修改数据

【Vue3】Pinia修改数据

背景

随着年龄的增长,很多曾经烂熟于心的技术原理已被岁月摩擦得愈发模糊起来,技术出身的人总是很难放下一些执念,遂将这些知识整理成文,以纪念曾经努力学习奋斗的日子。本文内容并非完全原创,大多是参考其他文章资料整理所得,感谢每位技术人的开源精神。

简介

本文介绍 Vue3 中如何修改 Pinia 中数据。

Pinia 是 Vue 专属的状态管理库,允许跨组件或页面共享数据。

开发环境

分类 名称 版本
操作系统 Windows Windows 11
IDE Visual Studio Code 1.91.1

开发步骤及源码

1> 在 【Vue3】Pinia存储及读取数据 基础上新增一个功能组件 Reader.vue,展示修改 Pinia 数据的第一种方法。

<template>
    <div class="reader">
        <button @click="borrow">借阅</button>
        <br>
        <h2>借阅图书</h2>
        <ol>
            <li v-for="book in books" :key="book.id">
                {
  { book.title }} : {
  { book.author }}
            </li>
        </ol>
    </div>
</template>

<script setup lang="ts">
import { useBookStore } from '@/store/book'
import { reactive } from 'vue';

const bookStore = useBookStore()
const books = reactive<any>([])

function borrow() {
    bookStore.bookCount -= 1
    const book = bookStore.books.shift()
    books.push(book)
}
</script>

<style scoped lang="scss">
.reader 
Vue 3 Pinia 是一个基于 Vue 3 的状态管理库,它提供了一种简单且高效的方式来存储和管理应用程序的数据Pinia 的核心概念是使用 Store 来存储数据,并通过使用类似于 Vuex 的方式来访问和修改数据。 要使用 Pinia 存储数据,首先需要创建一个 Store。可以通过定义一个类来创建 Store,并在类中定义数据和方法。以下是一个简单的示例: ```javascript import { createPinia } from &#39;pinia&#39;; const pinia = createPinia(); class MyStore { // 定义数据 count = 0; // 定义方法 increment() { this.count++; } decrement() { this.count--; } } // 注册 Store pinia.use(MyStore); export default pinia; ``` 在上面的示例中,我们创建了一个名为 MyStore 的 Store,并定义了一个名为 count 的数据和两个方法 increment 和 decrement。接下来,我们需要在应用程序的入口文件中注册 Store。 ```javascript import { createApp } from &#39;vue&#39;; import App from &#39;./App.vue&#39;; import pinia from &#39;./pinia&#39;; const app = createApp(App); // 注册 Pinia app.use(pinia); app.mount(&#39;#app&#39;); ``` 现在,我们可以在组件中使用 Store 来存储和访问数据。以下是一个使用 Store 的组件示例: ```vue <template> <div> <p>Count: {{ $store.count }}</p> <button @click="$store.increment()">Increment</button> <button @click="$store.decrement()">Decrement</button> </div> </template> <script> export default { name: &#39;MyComponent&#39;, }; </script> ``` 在上面的示例中,我们通过 `$store` 访问 Store 中的数据和方法。通过 `$store.count` 可以获取 count 的值,通过 `$store.increment()` 和 `$store.decrement()` 可以调用对应的方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

又言又语

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值