【Vue3进阶】- Pinia

什么是Pinia

Pinia 是 Vue 的专属状态管理库,它允许你跨组件或页面共享状态。它提供了类似于 Vuex 的功能,但比 Vuex 更加简单和直观

需要在多个组件之间共享状态或数据时使用 Pinia 的 store,这样可以避免 props 和 eventBus 等传统方法的复杂性,使状态管理更加集中和可维护。

安装

  1. 在终端中输入 npm install pinia
  2. 在main.js中引入 pinia,并且通过 app.use() 安装;
import { createApp } from 'vue'
import { createPinia } from 'pinia'   // 引入
import App from './App.vue'const pinia = createPinia() 	      // 创建实例
const app = createApp(App)app.use(pinia)			      // 安装使用
app.mount('#app')

定义Store

一般会在 store 目录下创建相应模块名字的js文件中定义;
例如:定义 user 模块要用到的 store,首先创建 /src/store/demo.js 文件。

未命名

接着使用 defineStore 方法定义 store:

  1. defineStore 定义的返回值(示例中的 useDemoStore)可以自己任意命名,但是建议以 use + store名字 + Store 的形式来定义(例如:useUserStore、useCartStore…)。

  2. defineStore 的第一个参数是应用中 Store 的唯一 ID(示例中的"demo")。

  3. defineStore 的第二个参数可接受两类值:Setup 函数Option 对象,后面内容将只介绍 Option 对象。

// /src/store/demo.jsimport { defineStore } from 'pinia'export const useDemoStore = defineStore('demo', {// 其他配置...
})

Option

State

state 是一个返回初始状态的函数

// /src/store/demo.jsimport { defineStore } from 'pinia'export const useDemoStore = defineStore('demo', {state: () => {return { // 在返回对象中定义要使用的数据count: 0,name: 'd2school',isAdmin: true,arr: [1,2,3]}},
})

访问state

使用定义的 store 实例就可以直接对其 state 进行读写
例如:上面定义的 store 返回值是 useDemoStore ,那么使用方式为:

import {useDemoStore} from "/src/store/demo.js";const demoStore = useDemoStore()  // store实例store.name     // 'd2school' 访问到state的内容
store.count++  // 1  进行修改

变更state

除了 store.count++ 直接对 state 进行修改,也可以使用 $patch 同时更改多个属性。

demoStore.$patch({count: demoStore.count + 1,name: 'd2school.com',isAdmin: false,
})

使用这种语法时,某些变更会比较麻烦或者耗时。
例如:对数组的增删操作,都需要创建一个新的集合,因此 $patch 方法也接受一个函数来进行变更。

demoStore.$patch((state) => {state.arr.push(3)state.isAdmin= false
})

重置state

使用 store 实例的 $reset() 方法可以将 state 重置为初始值。

import {useDemoStore} from "/src/store/demo.js";const demoStore = useStore() // store实例demoStore.$reset()   // 重置

Getter

getter 是 state 的计算值,建议使用箭头函数,它将接收 state 作为第一个参数。
在 getter 中可以使用 this 访问到整个 store 实例

// /src/store/count.js
export const useCountStore = defineStore('count', {state: () => ({count: 1,}),getters: {// 返回2倍数的countdoubleCount(state) {return state.count * 2},// 返回两倍的count并且+1doublePlusOne(){return this.doubleCount + 1  // 可以使用this访问到整个store实例},  
},
})

直接在 store 实例上访问 getter。

<script setup>import { useCounterStore } from '/src/store/counterStore.js'
const countStore = useCountStore ()countStore.doubleCount    //  2
countStore.doublePlusOne  //  3</script><template><p>{{ store.count}}</p><p>{{ store.doubleCount }}</p>
</template>

Action

action 相当于组件的 methods,可以执行异步操作,处理业务逻辑。

import {defineStore} from 'pinia'export const useDemoStore = defineStore('demo', {// 其他配置...state: () => {return {count: 0}},actions: {modifyCount(val) {this.count = val < 5 ? val : 0 // val小于5则赋值val否则赋值0}}
})

同样可以直接在 store 实例上访问 actions。

import {useDemoStore} from "./store/demo.js";
import {ref} from "vue";const store = useDemoStore()
let count = ref(0)function change() {count.value++store.modifyCount(count.value)
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3032244.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

计算机毕业设计 | vue+springboot线上考试 在线测试系统(附源码)

1&#xff0c;项目介绍 项目背景 在线考试借助于网络来进行&#xff0c;传统考试所必备的考场和监考对于在线考试来说并不是必要项目&#xff0c;因此可以有效减少组织考试做需要的成本以及设施。同时&#xff0c;由于在线考试系统本身具有智能阅卷的功能&#xff0c;也大大减…

不容错过的秘籍:JavaScript数组的创建和使用详解

在编程的世界里&#xff0c;数据是构建一切的基础。而在JavaScript中&#xff0c;有一种特殊且强大的数据结构&#xff0c;它就是——数组。 今天&#xff0c;我们就来一起探索数组的奥秘&#xff0c;从创建到使用&#xff0c;一步步掌握这个重要的工具。 一、什么是数组 数…

AI原生实践:测试用例创作探索

测试用例作为质量保障的核心&#xff0c;影响着研发-测试-发布-上线的全过程&#xff0c;如单元测试用例、手工测试用例、接口自动化用例、UI 自动化用例等&#xff0c;但用例撰写的高成本尤其是自动化用例&#xff0c;导致了用例的可持续积累、更新和迭代受到非常大制约。长久…

振弦采集仪在岩土工程监测中的数据处理与结果展示

振弦采集仪在岩土工程监测中的数据处理与结果展示 河北稳控科技振弦采集仪是岩土工程监测中常用的一种设备&#xff0c;用于采集地下土体振动信号&#xff0c;通过对数据的处理与结果的展示&#xff0c;可以有效地评估土体的动力特性和工程的稳定性。 振弦采集仪通过安装在土体…

(44)5.11第五章树和二叉树(树的基本概念)

1.树的基本概念 2.基本术语 2.1结点之间的关系 2.2结点&#xff0c;树的属性描述 2.3数和森林 2.4有序树和无序树 小结 3.树的性质 3.1树的常考性质 小结

又一位互联网大佬转行当网红,能写进简历么?

最近半个月&#xff0c;有两个中年男人仿佛住进了热搜。 一个是刚刚辟谣自己“卡里没有冰冷的 40 亿”的雷军&#xff0c;另一个则是在今年年初就高呼“如果有可能&#xff0c;企业家都要去当网红”的 360 创始人周鸿祎。 他也确实做到了。 先是作为当年 3Q 大战的当事人&…

手机格式化后数据还能恢复吗?恢复指南来了!

“手机被人捡走了&#xff0c;找回来后发现被格式化了&#xff0c;照片和聊天记录所有数据都没有了。手机格式化后数据还能恢复吗&#xff1f;难过到无法自拔&#xff0c;有没有类似情况但是恢复了数据的朋友回答一下&#xff1f;” 手机格式化是指将存储设备上的所有数据批量…

数据中心运维智能化管理 效果多炸裂?

从人工走向智能&#xff0c;一切的变化来源于数据中心规模化、系统复杂性和设备多样性的挑战&#xff0c;将平台运维的重要性推到了高点。 #01 为何要智能化&#xff1f; — 企业IT建设不断深入和完善&#xff0c;业务对系统稳定性和连续性的依赖&#xff0c;智能化将是更好…

Substrate 入门课第 14 期圆满结束,岗位内推直达知名 Web3 项目!

Substrate&#xff0c;一个完全免费且开源的框架&#xff0c;利用 Rust 语言的强大功能和安全性&#xff0c;为全球开发者提供了一个高效和灵活的开发环境。借助其模块化的设计&#xff0c;即使是新手开发者也能在短短 15 分钟内搭建起定制化的区块链。自 2020 年以来&#xff…

AIGC|将GPTBots与10000+主流软件连接,实现应用场景全覆盖

一、自动化工作流的无限可能&#xff0c;由AI带来 当前市场上存在许多自动化工作流工具&#xff0c;这些工具在很大程度上提升了人们的工作效率&#xff0c;为企业节省了大量时间和人力成本。然而&#xff0c;这些工具并非万能&#xff0c;它们在实际应用中仍存在一定的局限性…

课程设计 大学生竞赛系统

课程设计 大学生竞赛系统 wx:help-assignment 学生用户&#xff1a; wx:help-assignment 首页&#xff1a;推荐一些竞赛&#xff0c;热门活动等&#xff1b; 广场&#xff1a;用户可以通过广场来发表动态&#xff0c;同时也可以查看别人发布的动态&#xff0c;并且可以 关注…

2D-3D 转换中,为什么世界坐标要扩充成四维, 图像坐标要扩充成三维?

总结 在计算机视觉和图形学中&#xff0c;将世界坐标扩充成四维&#xff0c;以及图像坐标扩充成三维&#xff0c;是为了便于运用齐次坐标&#xff08;homogeneous coordinates&#xff09;进行坐标变换。这样的做法简化了投影变换的数学表示和计算&#xff0c;特别是在三维场景…

软件从立项申报到验收交付全资料整理(项目经理)

软件文档交付清单是指在软件开发项目完成后&#xff0c;开发团队需要准备的一份详细清单&#xff0c;用于确保交付的软件产品符合客户需求并达到预期的质量标准。以下是软件文档交付清单中可能包含的一些关键要素 项目启动阶段&#xff1a; 项目计划书/立项报告&#xff1a;描…

来看一段有趣的代码

最近实现发票连续打印时&#xff0c;直接copy其他项目代码来用&#xff0c;主要是对文件的处理&#xff0c;这部分可以不涉及数据库操作&#xff0c;这种功能也很方便写单元测试。在写单元测试图片转PDF功能时&#xff0c;发现了一段有趣的代码&#xff1a; protected void sc…

瑞芯微 rk3588 Linux系统备份还原 StepbyStep

1.系统备份 1.1 将瑞芯微平台嵌入式系统的root ssh 权限开通 step1:sudo vi /etc/ssh/sshd_config step2: 找到PermitRootLogin,把开关打开&#xff1a; PermitRootLogin yes step3:重启ssh服务 sudo systemctl restart sshd 1.2.使用瑞芯微的打包脚本把嵌入式系统系统打包 这…

操作系统实战(二)(linux+C语言)

实验内容 通过Linux 系统中管道通信机制&#xff0c;加深对于进程通信概念的理解&#xff0c;观察和体验并发进程间的通信和协作的效果 &#xff0c;练习利用无名管道进行进程通信的编程和调试技术。 管道pipe是进程间通信最基本的一种机制,两个进程可以通过管道一个在管道一…

代码审计平台sonarqube的安装及使用

docker搭建代码审计平台sonarqube 一、代码审计关注的质量指标二、静态分析技术分类三、使用sonarqube的目的四、sonarqube流程五、docker快速搭建sonarqube六、sonarqube scanner的安装和使用七、sonarqube对maven项目进行分析八、sonarqube分析报告解析九、代码扫描规则定制十…

激光雷达赋能盲人导航:精准安全与实施挑战并存

在当今科技的推动下&#xff0c;一款名为“蝙蝠避障”专门为盲人设计的辅助应用正逐渐成为他们独立出行的重要工具&#xff0c;特别是那些融入了激光雷达技术的应用&#xff0c;为盲人导航提供了前所未有的支持。然而&#xff0c;任何技术都有其两面性&#xff0c;接下来我们将…

Fcos源码训练编译问题

训练fcos代码时出现问题 ImportError: cannot import name ‘_C’ 原因是没有对代码进行编译 运行python setup.py develop --no-deps进行代码编译 编译过程中出现报错&#xff1a; fcos_core/csrc/cuda/ROIAlign_cuda.cu:5:10: fatal error: THC/THC.h: No such file or dire…

【Hugging Face】编写 shell 脚本在 huggingface 镜像站快速下载模型文件

前言 我们使用 Git LFS 和 wget 结合的方法&#xff0c;小文件使用 Git 下载&#xff0c;大文件使用 wget 下载 Git 下载的优缺点&#xff1a; 优点&#xff1a;相当简单 缺点&#xff1a;不支持断点续传 直接 wegt 下载比较稳定&#xff0c;但是欠缺优雅 我们可以将这两…