VUE3封装一个Hook
在 Vue 3 中,Composition API 让我们能够封装和复用代码逻辑,尤其是通过 setup 函数进行组件间的复用。为了提高代码的可复用性,我们可以把一些常见的 API 请求和状态管理逻辑封装到一个单独的 hook 中。
以下是一个简单的例子,我们将封装一个用于获取用户数据的 API 请求,并提供用于处理请求的状态、错误和数据的逻辑:
示例:封装 API 请求 Hook
// useUserData.ts
import { ref } from 'vue'
import { getUserData } from '@/api/user' // 假设这是你定义的API请求export function useUserData() {const userData = ref(null) // 存储用户数据const isLoading = ref(false) // 请求加载状态const error = ref(null) // 错误信息// 获取用户数据的函数const fetchUserData = async () => {isLoading.value = trueerror.value = nulltry {const response = await getUserData() // 假设这是一个返回用户数据的 API 请求userData.value = response.data} catch (err) {error.value = err.message || '获取数据失败'} finally {isLoading.value = false}}// 返回状态和操作return {userData,isLoading,error,fetchUserData,}
}
组件中使用这个 Hook
// UserProfile.vue
<template><div><button @click="fetchUserData" :disabled="isLoading">获取用户数据</button><div v-if="isLoading">加载中...</div><div v-if="error">{{ error }}</div><div v-if="userData"><p>用户名:{{ userData.name }}</p><p>年龄:{{ userData.age }}</p><!-- 更多用户信息展示 --></div></div>
</template><script lang="ts" setup>
import { useUserData } from '@/hooks/useUserData' // 引入封装好的Hook// 使用 Hook
const { userData, isLoading, error, fetchUserData } = useUserData()// 在组件加载时触发获取用户数据
onMounted(() => {fetchUserData()
})
</script>
优化:
通过将 API 请求逻辑和状态管理封装到 useUserData 中,你可以在不同的组件中轻松复用这一逻辑,只需要导入并调用 useUserData 即可。这样,组件的逻辑更加简洁,同时 API 请求逻辑也可以集中管理,增强了代码的可维护性和复用性。
举个例子:
假设你有多个页面或组件需要进行用户数据的请求,你只需要在这些组件中调用 useUserData,而无需重复编写相同的请求和状态管理逻辑。
另一个组件复用:
// UserDetails.vue
<template><div><h3>User Details</h3><button @click="fetchUserData" :disabled="isLoading">获取用户数据</button><div v-if="isLoading">加载中...</div><div v-if="error">{{ error }}</div><div v-if="userData"><p>用户名:{{ userData.name }}</p><p>电子邮件:{{ userData.email }}</p></div></div>
</template><script lang="ts" setup>
import { useUserData } from '@/hooks/useUserData'const { userData, isLoading, error, fetchUserData } = useUserData()onMounted(() => {fetchUserData()
})
</script>
通过这种封装的方式,API 请求和相关的状态管理都得到了有效的抽象。每个需要获取用户数据的组件,只需简单调用 useUserData,使得代码变得更简洁、可维护且易于复用。
相关文章:
VUE3封装一个Hook
在 Vue 3 中,Composition API 让我们能够封装和复用代码逻辑,尤其是通过 setup 函数进行组件间的复用。为了提高代码的可复用性,我们可以把一些常见的 API 请求和状态管理逻辑封装到一个单独的 hook 中。 以下是一个简单的例子,我…...
【Spring Boot】Spring AOP 快速上手指南:开启面向切面编程新旅程
前言 🌟🌟本期讲解关于spring aop的入门介绍~~~ 🌈感兴趣的小伙伴看一看小编主页:GGBondlctrl-CSDN博客 🔥 你的点赞就是小编不断更新的最大动力 🎆那么废话不…...
HTML基础入门——简单网页页面
目录 一,网上转账电子账单 编辑 1,所利用到的标签 2,代码编写 3,运行结果 二,李白诗词 1,所用到的标签 2,照片的编辑 3,代码编写 4,运行结果 一,网…...
INT301 Bio Computation 题型整理
perceptron 设计和计算 1. XOR: 当两个输入值中只有一个为真时,输出为真 2. 3. 5. 6. 7. 2^3 2^n 9. a) 直接test b) 把v≥2 改成 v≥1 10. no, because it cant be separate through only one decision boundary,its not linearlly separable. Backpropagatio…...
机器学习免费使用的数据集及网站链接
机器学习领域存在许多可以免费使用的数据集,这些数据集来自于学习、研究、比赛等目的。 一、综合性数据集平台 1.Kaggle 网址:Kaggle 数据集https://www.kaggle.com/datasets Kaggle是一个数据科学竞赛和社区平台,提供了大量的数据集供用…...
低空经济——飞行汽车运营建模求解问题思路
1. 掌握问题背景和领域知识 目标: 理解飞行汽车及其运营问题的核心要素和应用背景。学习内容: 飞行汽车基础: 了解飞行汽车的技术特点(垂直起降、电动推进等)。阅读行业报告,如 Uber Elevate 白皮书。共享…...
英伟达Project Digits赋能医疗大模型:创新应用与未来展望
英伟达Project Digits赋能医疗大模型:创新应用与未来展望 一、引言 1.1 研究背景与意义 在当今数字化时代,医疗行业作为关乎国计民生的关键领域,正面临着前所未有的挑战与机遇。一方面,传统医疗模式在应对海量医疗数据的处理、复…...
【Python3】异步操作 redis
aioredis 在高版本已经不支持了, 不要用 代码示例 redis 连接池异步操作redis以及接口 import asyncio from sanic import Sanic from sanic.response import json import redis.asyncio as redis from redis.asyncio import ConnectionPool# 创建 Sanic 应用 app…...
【W800】UART 的使用与问题
1.开发环境 OS: Windows 11开发板:海凌科 HLK-W800-KIT-PROSDK: W80X_SDK_v1.00.10IDE: CSKY Development Kit 2.UART 使用 在 SDK 中创建文件 uart_test.h 和 uart_test.c,然后在 CDK 项目中添加这两个文件,CDK 会自动 include 头文件。 …...
UART串口数据分析
串口基础知识详细介绍: 该链接详细介绍了串并行、单双工、同异步、连接方式 https://blog.csdn.net/weixin_43386810/article/details/127156063 该文章将介绍串口数据的电平变化、波特率计算、脉宽计算以及数据传输量的计算。 捕获工具:逻辑分析仪&…...
NFS 组件容器化部署实战指南
文章目录 前言部署NFS服务器K8S部署NFS问题记录 前言 使用nfs-client-provisioner这个应用,利用nfs server给kubernets提供作为持久化后端,并且动态提供pv。所有节点需要安装nfs-utils组件,并且nfs服务器与kubernets worker节点都能网络连通…...
嵌入式软件C语言面试常见问题及答案解析(三)
嵌入式软件C语言面试常见问题及答案解析(三) 上一篇已经足够长了,再长也就有点不礼貌了,所以在这儿继续来总结分享那个面试中遇到的题目,文中的问题和提供的答案或者代码均代表个人的理解,如有不合理或者错误的地方,欢迎大家批评指正。 本文中题目列表 1. 编码实现子串定…...
nvm安装教程
Node Version Manager (NVM) 是一个用来管理多个 Node.js 版本的命令行工具。使用 NVM,你可以在同一台机器上轻松安装和切换不同的 Node.js 版本。以下是针对 Unix 类系统(如 Linux 和 macOS)的 NVM 安装教程: 安装 NVM 更新系统…...
单片机-定时器中断
1、相关知识 振荡周期1/12us; //振荡周期又称 S周期或时钟周期(晶振周期或外加振荡周期)。 状态周期1/6us; 机器周期1us; 指令周期1~4us; ①51单片机有两组定时器/计数器,因为既可以定时,又可以计数,故称之为定时器…...
Hadoop 实战笔记(一) -- Windows 安装 Hadoop 3.x
环境准备 安装 JAVA 1.8 Java环境搭建之JDK下载及安装下载 Hadoop 3.3.5 安装包 Hadoop 下载:https://archive.apache.org/dist/hadoop/common/ 一、JAVA JDK 环境检查 二、Hadoop(HDFS)环境搭建 1. 解压安装文件 hadoop-3.3.5.tar 2. 配置环境变量 HADOOP_HO…...
AI中的神经元与权重矩阵之间的关系;神经元连接角度看行和列的意义
AI中的神经元与权重矩阵之间的关系 目录 AI中的神经元与权重矩阵之间的关系神经元连接角度看行和列的意义AI中的神经元概念 在人工智能领域,特别是神经网络中,神经元是基本的计算单元,它是对生物神经元的一种抽象模拟。就像生物神经元接收来自其他神经元的电信号,经过处理后…...
mysql、postgresql、druid链接池踩坑记录
The last packet successfully received from the server wIs 10,010 milliseconds ago. The last packet sent successfully to the server was 10,010 milliseconds ago.### The error may exist in URL mysql 链接字符串没有 &connectTimeout600000&socketTimeout6…...
NRF24L01模块STM32通信-通信初始化
目录 前言 一、IO口初始化 二、模拟SPI的基础代码 1.一些代码的宏定义 2.起始信号 3.CS,SCK,MOSI操作 4.MISO,IRQ操作 三.中间层代码 1.字节的输入和读取 2.写操作 3.读操作 四.应用层代码 1.24L01的检测 2.在main函数进行简单验证 3.24L01宏定义的代码 总结 前…...
高比例压缩:Linux 中的压缩命令与技巧
文章目录 高比例压缩:Linux 中的压缩命令与技巧1. 压缩格式的选择2. gzip 命令示例:压缩文件示例:解压文件 3. bzip2 命令示例:压缩文件示例:解压文件 4. xz 命令示例:压缩文件示例:解压文件 5.…...
LabVIEW软件Bug的定义与修改
在LabVIEW软件开发过程中,bug(程序错误或缺陷)指的是程序中导致不符合预期行为的任何问题。Bug可能是由于编码错误、逻辑漏洞、硬件兼容性问题、系统资源限制等因素引起的。它可能会导致程序崩溃、功能无法正常执行或输出结果不符合预期。理解…...
Sokol动画系统:如何在跨平台C/C++项目中实现流畅的2D与3D动画效果
Sokol动画系统:如何在跨平台C/C项目中实现流畅的2D与3D动画效果 【免费下载链接】sokol minimal cross-platform standalone C headers 项目地址: https://gitcode.com/gh_mirrors/so/sokol Sokol是一个极简的跨平台独立C头文件库,专门为游戏和图…...
深入浅出Linux ftrace:从内核配置到实战分析(附debugfs挂载全流程)
深入浅出Linux ftrace:从内核配置到实战分析 在Linux系统开发与调试过程中,内核级追踪工具的重要性不言而喻。面对复杂的系统行为、性能瓶颈或难以复现的偶发问题,传统的日志和调试手段往往力不从心。ftrace作为Linux内核原生提供的轻量级追踪…...
IFC格式是什么?用什么软件可以打开?
IFC格式介绍 IFC(Industry Foundation Classes)是一种开放的数据模型和文件格式,用于与建筑、工程和设施管理相关的信息交换。它是建筑信息模型(BIM)中常用的一种文件格式,包含了各种与建筑相关的信息&…...
【技术解析】LENFusion:如何通过循环反馈与双注意力机制,实现夜间图像融合与低光增强的协同优化?
1. 夜间图像处理的痛点与现有方案局限 当我们需要在夜间或低光照环境下获取清晰的图像时,通常会遇到两个关键问题:一是可见光图像太暗导致细节丢失,二是红外图像虽然能穿透黑暗但缺乏色彩和纹理信息。传统解决方案往往采用"先增强后融合…...
告别ArcGIS!用GEE+QGIS搞定流域DEM下载与地形分析(附完整代码)
告别ArcGIS!用GEEQGIS搞定流域DEM下载与地形分析(附完整代码) 在GIS领域,数字高程模型(DEM)是地形分析的基础数据。传统上,ArcGIS凭借其完善的功能和稳定的性能,成为DEM处理的首选工…...
2025届必备的六大AI辅助写作平台横评
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 进行学术写作以及内容创作之际,使文本的AI生成痕迹得以降低,这是提升…...
DoubleResetDetector_Generic:嵌入式双复位检测库技术解析
1. DoubleResetDetector_Generic 库深度技术解析:跨平台双复位检测的工程实现1.1 工程需求与设计动机在嵌入式设备的生命周期管理中,“如何安全、可靠地进入配置模式”是一个被反复验证却始终缺乏标准化解法的核心问题。传统方案如物理按键、专用跳线或串…...
AI赋能学术写作:六种智能文献引用生成与管理策略
核心工具对比速览 工具名称 核心优势 适用场景 处理速度 AiBiye 智能识别引用格式,自动匹配规范 学术论文初稿 3-5秒/页 AiCheck 深度检测引用缺失,精准定位问题 论文终稿检查 10秒/篇 AskPaper 多语言引用规范支持 国际期刊投稿 5-8秒/页…...
PaddlePaddle-GPU环境配置:为什么你的显卡总是被识别成CPU?(附解决方案)
PaddlePaddle-GPU环境配置:为什么你的显卡总是被识别成CPU?(附解决方案) 刚拿到新显卡准备大展拳脚,却发现PaddlePaddle死活不认GPU,这种挫败感我太懂了。明明花大价钱买的显卡,结果深度学习训…...
机器学习中七种常见的数据泄露原因
原文:towardsdatascience.com/seven-common-causes-of-data-leakage-in-machine-learning-75f8a6243ea5 当我在评估 ChatGPT、Claude 和 Gemini 等 AI 工具用于机器学习用例时,如我在上一篇文章中所述,我遇到了一个关键陷阱:机器学…...
