当前位置: 首页 > 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

http://www.lryc.cn/news/310821.html

相关文章:

  • ExoPlayer 播放视频黑屏的解决方法
  • C语言初阶—数组
  • 飞桨(PaddlePaddle)数据预处理教程
  • MYSQL C++链接接口编程
  • 并发编程中常见的设计模式,c++多线程如何设计
  • 解决android studio build Output中文乱码
  • [云原生] K8s之pod进阶
  • [Unity3d] 网络开发基础【个人复习笔记/有不足之处欢迎斧正/侵删】
  • Tomcat的配置文件
  • 猴子吃桃问题(python版)
  • C语言入门到精通之练习49:读取7个数(1—50)的整数值,每读取一个值,程序打印出该值个数的 *。
  • 如何在Windows轻量应用服务器上安装和配置SSH?
  • leetcode日记(36)全排列
  • Flink:动态表 / 时态表 / 版本表 / 普通表 概念区别澄清
  • 异常网络下TCP的可靠服务机制(慢启动、拥塞避免、快重传、快恢复)
  • PL/SQL执行.sql文件
  • 赋能中国制造,大道云行发布智能制造分布式存储解决方案
  • MySQL Strict Mode is not set for database connection ‘default‘
  • 分享:大数据信用报告查询的价格一般要多少钱?
  • tomcat下载安装配置教程
  • GO—变量
  • 【计算机毕业设计】044学生管理系统
  • 揭秘App访问量背后的秘密:数据统计与分析
  • Qt 样式表
  • leetcode hot100 每日温度
  • 【Java EE初阶二十六】简单的表白墙(二)
  • 【wpf】关于绑定的一点明悟
  • 叠罗汉游戏
  • 太阳能风吸式杀虫灯是什么
  • SpringBoot启动扩展应用:干预优化+加快启动时间