【Vue3】Pinia storeToRefs 解构

【Vue3】Pinia storeToRefs 解构

背景

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

简介

本文介绍 Vue3 中如何使用 storeToRefs 实现 Pinia Store 解构。

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

为了在提取 Pinia Store 中的属性时保持其响应性,Pinia 提供了 storeToRefs(),它将为每一个响应式属性创建引用。storeToRefs() 适用于只使用 Store 的状态而不调用任何 action 的场景。

开发环境

分类名称版本
操作系统WindowsWindows 11
IDEVisual Studio Code1.91.1

开发步骤及源码

【Vue3】Pinia存储及读取数据 基础上修改功能组件 Book.vue

<template>
    <div class="books">
        <h2>图书数量:{{ bookCount }}</h2>
        <h2>图书列表</h2>
        <ul>
            <li v-for="book in books" :key="book.id">
                {{ book.title }} -- {{ book.author }}
            </li>
        </ul>
    </div>
</template>

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

const bookStore = useBookStore()
const { bookCount, books } = storeToRefs(bookStore)
</script>

<style scoped lang="scss">
.books {
    background-color: aquamarine;
    padding: 20px;
    li {
        font-size: 20px;
        height: 35px;
        line-height: 35px;
    }
}
</style>

使用 storeToRefs 解构后,<template> 中引用数据不再需要 bookStore. 前缀。

执行命令 npm run dev 启动应用,浏览器访问:http://localhost:5173/,与修改前页面表现一致。

注意:Pinia 中 storeToRefs 与 Vue 原生提供的 ToRefs 最大的区别在于,Pinia 中 storeToRefs 只关注 Store 中的数据,不会对此外的其他部分进行 ref 包裹。

引用\[1\]和\[2\]提供了关于在Vue3中使用Pinia进行模块化的示例代码。Pinia是一个用于状态管理的库,可以帮助开发者在Vue应用中更好地组织和管理状态。在示例代码中,我们可以看到如何在main.ts中创建Pinia实例并将其挂载到应用程序上,以及如何在store.ts中定义和使用Pinia的插件和模块。通过使用Pinia,我们可以使用不同的写法(options API或setup模式)来定义和注册全局的store模块。 引用\[3\]提供了一个关于解构变量后再watch的示例代码。在这个示例中,我们可以看到如何使用storeToRefsstore中的变量解构为响应式的引用,并在watch函数中监视其中一个变量的变化。然而,需要注意的是,由于解构变量后再watch可能会导致无法检测到变量的变化,所以在这个示例中,fruit变量的变化可能无法被正确地检测到。 综上所述,Pinia是一个用于在Vue3中进行状态管理的库,可以帮助开发者更好地组织和管理应用程序的状态。通过使用Pinia,我们可以使用不同的写法来定义和注册全局的store模块,并且可以使用插件来实现数据持久化。然而,在解构变量后再watch时,可能会导致无法正确检测到变量的变化。 #### 引用[.reference_title] - *1* *2* *3* [vue3 pinia模块化记录](https://blog.csdn.net/weixin_44624120/article/details/128819797)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

又言又语

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

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

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

打赏作者

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

抵扣说明:

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

余额充值