当前位置: 首页 > news >正文

Vue3:使用 Composition API 不需要 Pinia

在 Vue.js 开发的动态环境中,在单个组件中处理复杂的业务逻辑可能会导致笨重的文件和维护噩梦。虽然 Pinia 提供集中式状态管理,但仅依赖它来处理复杂的业务逻辑可能会导致代码混乱。本文探讨了使用 Composition API 的替代方法,说明开发人员如何将数据和逻辑封装在自定义 hooks 中以实现高效的状态管理。

驾驭复杂的业务逻辑

在日常开发中,经常会出现功能变得过于复杂而无法限制在单个 Vue.js 组件中的情况。分解组件是合乎逻辑的解决方案,但这带来了在组件之间共享数据和业务逻辑的挑战。虽然 Pinia 在这方面很受欢迎,但如果广泛用于所有复杂的业务逻辑,它就会变得不堪重负。

拥抱 Composition API 和自定义 Hook

一个引人注目的替代方案是利用 Composition API 将数据和业务逻辑封装在自定义 hooks 中。这些钩子(以 useStore 函数为例)成为状态定义、更新和特定业务逻辑的中心。反过来,组件只需要与这些钩子公开的状态和方法进行交互,从而抽象出内部的复杂性。

// 使用 Composition API 自定义 hook
import { computed, ref } from "vue";// 在 useStore 函数外部定义 count 变量
const count = ref(0);
const doubleCount = computed(() => {return count.value * 2;
});export const useStore = () => {function increment() {count.value = count.value + 1;}function decrement() {count.value = count.value - 1;}return {count,doubleCount,increment,decrement,};
};

孤立的 Hook 调用的陷阱

CountValueCountBtn 等组件在其 setup 函数中独立调用 useStore 挂钩时,就会出现挑战。本文揭示了每次调用时创建 count 变量的独立实例的陷阱,从而导致组件之间的状态更新不一致。

// CountValue.vue component
<template><p>count's value is {{ count }}</p><p>doubleCount's value is {{ doubleCount }}</p>
</template><script setup lang="ts">
import { useStore } from "./store";// 对 useStore 的独立调用创建独立的 count 实例
const { count, doubleCount } = useStore();
</script>// CountBtn.vue component
<template><button @click="decrement">count--</button><button @click="increment">count++</button>
</template><script setup lang="ts">
import { useStore } from "./store";// 对 useStore 的独立调用创建独立的 count 实例
const { decrement, increment } = useStore();
</script>

协调组件之间的状态

为了克服这一挑战,一种优化方法是将 count 变量的定义重新定位到 useStore 函数之外。这可确保调用 useStore hook 的所有组件共享 count 变量的同一实例,从而促进同步状态管理。

// 将计数定义移至 useStore 函数之外
import { computed, ref } from "vue";const count = ref(0);
const doubleCount = computed(() => {return count.value * 2;
});export const useStore = () => {function increment() {count.value = count.value + 1;}function decrement() {count.value = count.value - 1;}return {count,doubleCount,increment,decrement,};
};

在 Pinia 似乎难以应对复杂业务逻辑的各个方面的情况下,Composition API 提供了一个干净、有组织的替代方案。通过将数据和逻辑封装在自定义钩子中,开发人员可以在 Vue.js 应用程序中的模块化和高效状态管理之间取得平衡。

本文强调了 Composition API 在构建 Vue.js 解决方案中的多功能性,以最大限度地提高灵活性和可维护性。通过采用自定义钩子,开发人员可以编写符合 Vue.js 原则的有组织、可读的代码。


原文:https://blog.stackademic.com/vue-3-you-dont-need-pinia-in-some-scenarios-with-the-composition-api-79fc4ff6ab8f

相关文章:

  • C++知识点总结(22):模拟算法真题 ★★★☆☆《安全警报》
  • 【LeetCode】1768_交替合并字符串_C
  • 牛市初期,Penpad 以 Fair Launch 方式推出首个资产 PEN
  • 如何创建测试计划?这些要考虑到
  • 【IO流系列】字符流练习(拷贝、文件加密、修改文件数据)
  • 一些可以访问gpt的方式
  • 如何选择适合电商的WordPress主题模板?
  • 在Spring Boot中如何实现异常处理?
  • 长贵对赵本山说:你需要我们家大脚,我立马给你配双大鞋!
  • 为什么要用Python?
  • leetcode热题100学习计划-链表-相交链表
  • 【清理mysql数据库服务器二进制日志文件】
  • 如何在 Linux 中快速清空文件而不删除它们?
  • 恭喜莱佛士学生在SPADE室内设计大赛中一举拿下11个奖项
  • 鸿鹄工程项目管理系统 Spring Cloud+Spring Boot+前后端分离构建工程项目管理系统
  • JS 中的深拷贝与浅拷贝
  • 【347天】每日项目总结系列085(2018.01.18)
  • 2018以太坊智能合约编程语言solidity的最佳IDEs
  • bootstrap创建登录注册页面
  • C# 免费离线人脸识别 2.0 Demo
  • CSS 提示工具(Tooltip)
  • Essential Studio for ASP.NET Web Forms 2017 v2,新增自定义树形网格工具栏
  • JavaScript设计模式之工厂模式
  • JavaScript异步流程控制的前世今生
  • Koa2 之文件上传下载
  • laravel with 查询列表限制条数
  • Lucene解析 - 基本概念
  • puppeteer stop redirect 的正确姿势及 net::ERR_FAILED 的解决
  • Spark RDD学习: aggregate函数
  • vue学习系列(二)vue-cli
  • Web标准制定过程
  • 记录:CentOS7.2配置LNMP环境记录
  • 力扣(LeetCode)357
  • 聊聊directory traversal attack
  • 我看到的前端
  • ​TypeScript都不会用,也敢说会前端?
  • # 飞书APP集成平台-数字化落地
  • $.ajax()
  • $Django python中使用redis, django中使用(封装了),redis开启事务(管道)
  • (2)MFC+openGL单文档框架glFrame
  • (C语言)二分查找 超详细
  • (C语言)求出1,2,5三个数不同个数组合为100的组合个数
  • (C语言)球球大作战
  • (Redis使用系列) Springboot 实现Redis消息的订阅与分布 四
  • (博弈 sg入门)kiki's game -- hdu -- 2147
  • (动手学习深度学习)第13章 计算机视觉---图像增广与微调
  • (九)信息融合方式简介
  • (十七)devops持续集成开发——使用jenkins流水线pipeline方式发布一个微服务项目
  • (原創) 人會胖會瘦,都是自我要求的結果 (日記)
  • .bashrc在哪里,alias妙用
  • .NET delegate 委托 、 Event 事件
  • .net 获取url的方法
  • .net开发引用程序集提示没有强名称的解决办法
  • .net利用SQLBulkCopy进行数据库之间的大批量数据传递
  • .NET牛人应该知道些什么(2):中级.NET开发人员