Pinia详解

文章目录

  • 简介
  • 特点
  • 用法
    • 1. 安装Pinia
    • 2. 注册Pinia Store
    • 3. 创建Pinia Store
    • 4. 使用Pinia Store
  • 区别

在这里插入图片描述

Vuex详解

Pinia是一个基于Vue 3的状态管理库,专为Vue 3设计。它提供了一种简单、直观且可扩展的方式来组织和访问应用程序的状态。Pinia的设计灵感来源于Vuex,但相比Vuex,Pinia更加轻量级、简单易用和灵活。Pinia利用Vue 3的新特性,如Composition API,使得开发者能够更容易地上手和使用。

简介

Pinia官网

Pinia是一个基于Vue 3的状态管理库,专为Vue 3设计。它提供了一种简单、直观且可扩展的方式来组织和访问应用程序的状态。Pinia的设计灵感来源于Vuex,但相比Vuex,Pinia更加轻量级、简单易用和灵活。Pinia利用Vue 3的新特性,如Composition API,使得开发者能够更容易地上手和使用。

特点

  • 轻量级:Pinia不需要使用Vuex中的一些复杂概念,如模块和getter,因此更加轻量级。

  • 简单易用:Pinia的API设计更加简单直观,特别是与Vue 3的Composition API紧密集成,使得开发者能够更快速地理解和使用。

  • 模块化状态管理:Pinia支持将状态划分为不同的模块,提高了代码的可维护性和可扩展性。

  • 状态订阅:Pinia允许开发者订阅状态的变化,并在状态发生变化时触发相应的回调函数。

  • 类型安全:Pinia支持TypeScript,并提供了类型安全的API和开发体验,使得在开发过程中能够更好地捕获错误和进行静态类型检查。

  • 支持异步操作:Pinia支持在actions中执行异步操作,如发送网络请求、处理副作用等。

用法

1. 安装Pinia

使用npm或yarn等包管理器安装Pinia库。

npm install pinia

yarn add pinia

2. 注册Pinia Store

在应用程序的入口文件中注册Pinia Store,以便它能够在整个应用程序中使用。

// main.js  
import { createApp } from 'vue'  
import { createPinia } from 'pinia'  
import App from './App.vue'  
  
const app = createApp(App)  
  
// 创建一个 Pinia 实例  
const pinia = createPinia()  
  
// 使用 Pinia  
app.use(pinia)  
  
app.mount('#app')

3. 创建Pinia Store

使用 defineStore 函数来创建一个Pinia Store,定义状态、getters 和 actions 等。

接下来,定义一个 Pinia store 来管理一个简单的计数器状态:

// stores/counter.js  
import { defineStore } from 'pinia'

// 你可以任意命名 `defineStore()` 的返回值,但最好使用 store 的名字,同时以 `use` 开头且以 `Store` 结尾。
// 第一个参数是你的应用中 Store 的唯一 ID。
export const useCounterStore = defineStore('counter', {
    // store 的数据 (data)
    state: () => ({
        count: 0
    }),
    
    // getters 是 store 的计算属性 (computed)
    getters: {
        // 可以通过 this 访问 state  
        doubleCount: (state) => state.count * 2
    },
    
    // actions 则是方法 (methods)
    actions: {
        increment () {
            this.count++
        },
        decrement () {
            if (this.count > 0) {
                this.count--
            }
        },
        // 异步操作示例  
        async fetchCountFromApi () {
            // 假设我们从一个 API 获取新的计数  
            const response = await fetch('https://api.example.com/count')
            const data = await response.json()
            this.count = data.count
        }
    }
    
})

4. 使用Pinia Store

在Vue组件中通过 useStore 函数来访问和使用 Pinia Store 中的状态。

<!-- App.vue -->
<template>
    <div>
        <p>Count: {{ counterStore.count }}</p>
        <p>Double Count: {{ counterStore.doubleCount }}</p>
        <button @click="counterStore.increment">Increment</button>
        <button @click="counterStore.decrement" :disabled="counterStore.count <= 0">Decrement</button>
        <!-- 假设我们有一个按钮来触发 API 调用 -->
        <button @click="counterStore.fetchCountFromApi">Fetch Count from API</button>
    </div>
</template>

<script>
    // 导入并使用 Pinia store
    import { useCounterStore } from './stores/counter';

    export default {
        setup() {
            // 使用 store
            const counterStore = useCounterStore();

            // 返回需要在模板中使用的响应式数据和方法
            return {
                counterStore
            };
        }
    };
</script>

上例中,导入这个 store,并在模板中使用了它的状态和方法。还添加了一个按钮来触发一个模拟的 API 调用,以更新计数器的值。

区别

特性VuexPinia
设计原则Flux-like更接近 Vue 3 的 Composition API
版本兼容性Vue 2, Vue 3主要针对 Vue 3
状态管理使用全局单一的 Store 来管理应用的状态使用独立的 store(与组件类似)来管理状态
状态结构模块化的,通过命名空间区分每个 store 都是独立的,易于测试和复用
Mutations强制使用,用于同步更新状态不需要 mutations,直接通过 actions 或 state 的直接赋值来更新状态
Actions用于异步操作或包含任意副作用的操作类似于 Vuex 的 actions,但更简洁,可以直接在 actions 中修改状态
Type Safety需要额外的工具或插件来支持天然的 TypeScript 支持,提供更好的类型安全
插件系统支持插件扩展支持通过 middleware(中间件)或 plugins(插件)来扩展功能
热模块替换 (HMR)支持,但需要额外配置支持,集成在 Pinia 内部
开发体验需要额外的学习成本,尤其是 mutations 的使用接近 Vue 3 的 Composition API,学习成本低
体积相对较大,包含额外的功能和抽象较小,只包含核心功能
社区支持成熟的社区和大量的教程/文档相对较新的项目,但正在迅速获得支持
适用场景大型、复杂的应用中小型到大型应用,尤其是需要更灵活状态管理的场景

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【proteus经典实战】16X192点阵程序

一、简介 6X192点阵程序通常用于表示高分辨率图像或文字&#xff0c;其中16X表示像素阵列的宽度&#xff0c;192表示每个像素阵列中的点阵数&#xff0c;16X192点阵程序需要一定的编程知识和技能才能编写和调试&#xff0c;同时还需要考虑硬件设备的兼容性和性能等因素。 初始…

玩游戏就能学习亚马逊云科技AWS技术并通过热门技术认证考试??

亚马逊AWS限时活动&#xff0c;玩免费游戏Cloud Quest Practitioner送AWS云从业证书考试25%折扣券(价值171元)&#xff0c;玩游戏的同时还能学知识一举两得。Cloud Quest是AWS出的一款3D角色扮演游戏/虚拟城市建造形式的实验课程(游戏画面有点像天际线)&#xff0c;大家通过完成…

FPV穿越机集群控制技术详解

随着无人机技术的不断发展&#xff0c;FPV&#xff08;First Person View&#xff0c;第一人称视角&#xff09;穿越机在娱乐、航拍、搜索与救援等领域的应用日益广泛。FPV穿越机集群控制技术则是这一领域的热点研究方向&#xff0c;旨在通过协同控制多个穿越机实现更高效、更复…

Efficient Unified Demosaicing for Bayer and Non-Bayer Patterned Image Sensors

这篇文章是 2023 ICCV 的一篇文章&#xff0c;主要介绍一套统一的去马赛克的算法框架的 由于手机 Camera 上 CMOS 的单个 pixel size 比较小&#xff0c;所以现在很多手机的 Camera CMOS 会采用一些独特的非 Bayer 模式的 CFA (Quad, Nona 以及 Q X Q) 等&#xff0c;这类非 B…

【Linux】已解决:Ubuntu虚拟机安装Java/JDK

文章目录 一、分析问题背景二、可能出错的原因三、错误代码示例四、正确代码示例五、注意事项结论 已解决&#xff1a;Ubuntu虚拟机安装Java/JDK 一、分析问题背景 在Ubuntu虚拟机上安装Java开发工具包&#xff08;JDK&#xff09;是许多开发者的常见任务。然而&#xff0c;在…

STM32音频应用开发:DMA与定时器的高效协作

摘要: 本文章将深入浅出地介绍如何使用STM32单片机实现音频播放功能。文章将从音频基础知识入手&#xff0c;逐步讲解音频解码、DAC转换、音频放大等关键环节&#xff0c;并结合STM32 HAL库给出具体的代码实现和电路设计方案。最后&#xff0c;我们将通过一个实例演示如何播放W…

! Warning: `flutter` on your path resolves to

目录 项目场景&#xff1a; 问题描述 原因分析&#xff1a; 解决方案&#xff1a; 1. 检查并更新.bash_profile或.zshrc文件 2.添加Flutter路径到环境变量 3. 加载配置文件 4.验证Flutter路径 5.重新启动终端 项目场景&#xff1a; 今天重新安装了AndroidStudio,并配置…

zdppy_api+vue3实现前后端分离的登录功能

实现思路 1、准备zdppy的开发环境 2、使用amauth提供的低代码接口&#xff0c;直接生成login登录接口 3、使用之前开发的登录模板渲染登录界面 4、给登录按钮绑定点击事件 5、给用户名和密码的输入框双向绑定数据 6、使用axios在登录按钮点击的时候&#xff0c;携带用户数据发…

Linux部署wordpress站点

先安装宝塔面板 yum install -y wget && wget -O install.sh https://download.bt.cn/install/install_6.0.sh && sh install.sh ed8484bec 因为wordpress需要php&#xff0c;mysql&#xff0c;apache &#xff0c;httpd环境 参考&#xff1a;Linux 安装宝塔…

【学习】使用PyTorch训练与评估自己的ResNet网络教程

参考&#xff1a;保姆级使用PyTorch训练与评估自己的ResNet网络教程_训练自己的图像分类网络resnet101 pytorch-CSDN博客 项目地址&#xff1a;GitHub - Fafa-DL/Awesome-Backbones: Integrate deep learning models for image classification | Backbone learning/comparison…

HBase Shell命令详解

HBase Shell命令 一、 命名空间 命名空间是 HBase 中用于组织表的一种逻辑容器&#xff0c;类似于文件系统中的文件夹。 Namespace允许用户在 HBase 中更好地管理和组织表&#xff0c;以及提供了隔离和命名约定。 1. 创建命名空间 命令&#xff1a; create_namespace name…

【scrapy】1.scrapy爬虫入门

一、scrapy爬虫框架 Scrapy 框架是一个基于Twisted的一个异步处理爬虫框架&#xff0c;应用范围非常的广泛&#xff0c;常用于数据采集、网络监测&#xff0c;以及自动化测试等。 scrapy框架包括5个主要的组件&#xff1a; Scheduler&#xff1a;事件调度器&#xff0c;它负…

机器学习引领教育革命:智能教育的新时代

&#x1f4dd;个人主页&#x1f339;&#xff1a;Eternity._ &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; ❀目录 &#x1f4d2;1. 引言&#x1f4d9;2. 机器学习在教育中的应用&#x1f31e;个性化学习&#x1f319;评估与反馈的智能化⭐教学资源的优…

Lua: 轻量级多用途脚本语言

Lua 是一种高效而轻量级的脚本语言&#xff0c;具备强大的扩展性和灵活性&#xff0c;广泛应用于游戏开发、嵌入式系统、Web 应用等多个领域。本文将深入探讨 Lua 的特性、应用场景以及如何使用 Lua 进行开发。 1. Lua 的起源与发展 Lua 的发展始于上世纪90年代初&#xff0c;…

Java单体架构项目_云霄外卖-特殊点

项目介绍&#xff1a; 定位&#xff1a; 专门为餐饮企业&#xff08;餐厅、饭店&#xff09;定制的一款软件商品 分为&#xff1a; 管理端&#xff1a;外卖商家使用 用户端&#xff08;微信小程序&#xff09;&#xff1a;点餐用户使用。 功能架构&#xff1a; &#xff08…

哎呀呀 又迟到了,还被抓住了,面面相觑 害怕

网络编程 我应该迟点来&#xff0c;唠嗑到35嘿嘿 心疼自己早起呜呜呜&#xff0c;幸运的是35开讲 计算机网络 分4层 应用层&#xff08;Application Layer&#xff09;&#xff1a; 应用层是用户接口和网络应用程序的接口。它允许用户访问网络服务&#xff0c;并支持各种应用程…

Windows系统下文件夹权限详解

文章目录 问题描述文件夹属性 问题描述 今天在Win10系统下&#xff0c;实现文件夹设置权限&#xff0c;具体的方案的涉及到我们公司内部的一款加密软件&#xff0c;不太方便透漏&#xff0c;借此机会&#xff0c;我也重新的回顾下windows系统下的文件夹权限 文件夹属性 打开…

[C++][设计模式][中介者模式]详细讲解

目录 1.动机2.模式定义3.要点总结 1.动机 在软件构建过程中&#xff0c;经常会出现多个对象相互关联的情况&#xff0c;对象之间常常会维持一种复杂的引用关系&#xff0c;如果遇到一些需求的更改&#xff0c;这种直接的引用关系将面临不断的变化在这种情况下&#xff0c;可以…

【小沐学AI】Python实现语音识别(whisper+HuggingFace)

文章目录 1、简介1.1 whisper 2、HuggingFace2.1 安装transformers2.2 Pipeline 简介2.3 Tasks 简介2.3.1 sentiment-analysis2.3.2 zero-shot-classification2.3.3 text-generation2.3.4 fill-mask2.3.5 ner2.3.6 question-answering2.3.7 summarization2.3.8 translation 3、…

PyTorch Tensor进阶操作指南(二):深度学习中的关键技巧

本文主要讲tensor的裁剪、索引、降维和增维 Tensor与numpy互转、Tensor运算等&#xff0c;请看这篇文章 目录 9.1、首先看torch.squeeze()函数&#xff1a; 示例9.1&#xff1a;&#xff08;基本的使用&#xff09; 小技巧1&#xff1a;如何看维数 示例9.2&#xff1a;&a…