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

Vue Hooks 深度解析:从原理到实践

Vue Hooks 深度解析:从原理到实践


前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家!点我试试!!

在这里插入图片描述

在这里插入图片描述

文章目录

  • Vue Hooks 深度解析:从原理到实践
    • 一、背景与核心概念
      • 1.1 什么是 Vue Hooks?
      • 1.2 为什么需要 Vue Hooks?
    • 二、核心 Hooks 解析
      • 2.1 `useState`:状态管理
      • 2.2 `useEffect`:副作用管理
      • 2.3 `useContext`:共享状态
    • 三、自定义 Hooks
      • 3.1 创建自定义 Hook
      • 3.2 组合多个 Hooks
    • 四、Hooks 最佳实践
      • 4.1 命名规范
      • 4.2 单一职责
      • 4.3 依赖管理
    • 五、性能优化
      • 5.1 减少重复渲染
      • 5.2 懒加载 Hooks
    • 六、Hooks 与 Class API 对比
    • 七、未来展望
    • 八、完整示例
      • 8.1 使用 Hooks 实现计数器
      • 8.2 使用 Hooks 实现数据获取

一、背景与核心概念

1.1 什么是 Vue Hooks?

Vue Hooks 是 Vue 3 引入的一种逻辑复用机制,借鉴了 React Hooks 的设计思想。它允许开发者在函数式组件中使用状态、生命周期等特性,从而更好地组织和管理代码逻辑。

1.2 为什么需要 Vue Hooks?

  • 逻辑复用:将组件逻辑抽离为可复用的函数。
  • 代码简洁:减少高阶组件和混入(mixin)的使用。
  • 更好的类型支持:函数式组件对 TypeScript 更友好。

二、核心 Hooks 解析

2.1 useState:状态管理

useState 是 Vue Hooks 中最基础的 Hook,用于在函数式组件中管理状态。

import { ref } from 'vue';function useState(initialValue) {const state = ref(initialValue);const setState = (newValue) => {state.value = newValue;};return [state, setState];
}

使用示例

export default {setup() {const [count, setCount] = useState(0);return {count,setCount,};},
};

2.2 useEffect:副作用管理

useEffect 用于处理副作用(如数据获取、事件监听等),类似于 Vue 2 中的 mountedupdated 生命周期钩子。

import { onMounted, onUpdated, onUnmounted } from 'vue';function useEffect(effect, deps) {onMounted(() => {effect();});onUpdated(() => {if (deps) {effect();}});onUnmounted(() => {// 清理逻辑});
}

使用示例

export default {setup() {useEffect(() => {console.log('Component mounted or updated');}, []);return {};},
};

2.3 useContext:共享状态

useContext 用于在组件树中共享状态,避免层层传递 props。

import { provide, inject } from 'vue';const Context = Symbol();function useProvideContext(value) {provide(Context, value);
}function useInjectContext() {return inject(Context);
}

使用示例

// 父组件
export default {setup() {useProvideContext({ theme: 'dark' });return {};},
};// 子组件
export default {setup() {const context = useInjectContext();return { context };},
};

三、自定义 Hooks

3.1 创建自定义 Hook

自定义 Hook 是一个 JavaScript 函数,其名称以 use 开头,内部可以调用其他 Hooks。

import { ref, onMounted } from 'vue';function useWindowWidth() {const width = ref(window.innerWidth);const updateWidth = () => {width.value = window.innerWidth;};onMounted(() => {window.addEventListener('resize', updateWidth);});onUnmounted(() => {window.removeEventListener('resize', updateWidth);});return width;
}

使用示例

export default {setup() {const width = useWindowWidth();return { width };},
};

3.2 组合多个 Hooks

自定义 Hook 可以组合多个 Hooks,实现更复杂的逻辑。

function useUserProfile(userId) {const profile = ref(null);const loading = ref(false);useEffect(async () => {loading.value = true;profile.value = await fetchUserProfile(userId);loading.value = false;}, [userId]);return { profile, loading };
}

使用示例

export default {setup() {const { profile, loading } = useUserProfile(123);return { profile, loading };},
};

四、Hooks 最佳实践

4.1 命名规范

  • 自定义 Hook 名称以 use 开头。
  • 使用有意义的名称,如 useFetchDatauseLocalStorage

4.2 单一职责

  • 每个 Hook 只负责一个功能。
  • 避免在 Hook 中处理过多逻辑。

4.3 依赖管理

  • 明确指定 useEffect 的依赖项,避免不必要的重复执行。
  • 使用 watchcomputed 处理复杂依赖。

五、性能优化

5.1 减少重复渲染

  • 使用 memocomputed 缓存计算结果。
  • 避免在渲染函数中创建新对象或函数。

5.2 懒加载 Hooks

  • 使用 defineAsyncComponent 异步加载组件。
  • 将 Hooks 逻辑拆分为独立模块,按需加载。

六、Hooks 与 Class API 对比

特性Hooks APIClass API
代码简洁性
逻辑复用方便依赖混入
类型支持优秀一般
学习曲线较低较高
性能优化灵活依赖生命周期

七、未来展望

  1. 生态扩展:更多官方和社区提供的 Hooks。
  2. 工具支持:更好的 DevTools 集成。
  3. 性能优化:更高效的渲染机制。

八、完整示例

8.1 使用 Hooks 实现计数器

<template><div><p>Count: {{ count }}</p><button @click="increment">Increment</button></div>
</template><script>
import { ref } from 'vue';export default {setup() {const count = ref(0);const increment = () => {count.value++;};return { count, increment };},
};
</script>

8.2 使用 Hooks 实现数据获取

<template><div><p v-if="loading">Loading...</p><p v-else>{{ data }}</p></div>
</template><script>
import { ref, onMounted } from 'vue';export default {setup() {const data = ref(null);const loading = ref(true);onMounted(async () => {const response = await fetch('/api/data');data.value = await response.json();loading.value = false;});return { data, loading };},
};
</script>

以上是关于 Vue Hooks 的深度解析文章,涵盖了核心概念、自定义 Hooks、最佳实践和未来展望。如果您有其他需求或需要进一步扩展某部分内容,请随时告诉我!🚀

_______________________________________________

相关文章:

Vue Hooks 深度解析:从原理到实践

Vue Hooks 深度解析&#xff1a;从原理到实践 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家&#xff01;点我试试&#xff01;&#xff01; 文章目录 Vue Hooks 深度解析&#xff1a;从原理到实践一、背景…...

5c/c++内存管理

1. C/C内存分布 int globalVar 1; static int staticGlobalVar 1; void Test() {static int staticVar 1;int localVar 1;int num1[10] { 1, 2, 3, 4 };char char2[] "abcd";const char* pChar3 "abcd";int* ptr1 (int*)malloc(sizeof(int) * 4);i…...

Android14 OTA差分包升级报Package is for source build

制作好差分包&#xff0c;使用adb线刷模式验证ota升级&#xff0c;出现E:Package is for source build错误 使用adb方式验证 进入recovery模式 adb reboot recovery稍等一会界面会提示 Now send the package you want to apply to the device with "adb sidelaod <…...

C++中的无锁编程

引言 在当今多核处理器普及的时代&#xff0c;并发编程已成为高性能应用程序开发的关键技术。传统的基于锁的同步机制虽然使用简单&#xff0c;但往往会带来性能瓶颈和死锁风险。无锁编程&#xff08;Lock-Free Programming&#xff09;作为一种先进的并发编程范式&#xff0c…...

7. 机器人记录数据集(具身智能机器人套件)

1. 树莓派启动机器人 conda activate lerobotpython lerobot/scripts/control_robot.py \--robot.typelekiwi \--control.typeremote_robot2. huggingface平台配置 huggingface官网 注册登录申请token&#xff08;要有写权限&#xff09;安装客户端 # 安装 pip install -U …...

设计模式 + java8方法引用 实现任意表的过滤器

会用到下面2个依赖&#xff0c;原因是在今天的案例中&#xff0c;我想在我代码中使用上Entity::getFieldName 这种形式 LambdaQueryWrapper<ApplicationDashboard> queryWrapper new LambdaQueryWrapper<>(); queryWrapper.eq(ApplicationDashboard::getAppCode,…...

分布式锁—5.Redisson的读写锁二

大纲 1.Redisson读写锁RedissonReadWriteLock概述 2.读锁RedissonReadLock的获取读锁逻辑 3.写锁RedissonWriteLock的获取写锁逻辑 4.读锁RedissonReadLock的读读不互斥逻辑 5.RedissonReadLock和RedissonWriteLock的读写互斥逻辑 6.写锁RedissonWriteLock的写写互斥逻辑…...

【C++设计模式】第七篇:桥接模式(Bridge)

注意&#xff1a;复现代码时&#xff0c;确保 VS2022 使用 C17/20 标准以支持现代特性。 抽象与实现的解耦之道 1. 模式定义与用途​​ 核心思想​ ​桥接模式&#xff1a;将抽象部分与实现部分分离&#xff0c;使二者可以独立变化。​关键用途&#xff1a; ​1.拆分复杂继承…...

Html常用代码

Html常用代码 文章目录 Html常用代码1-常用的Html代码1-Html模板 2-快速部署Live-Server1-Windows系统步骤 1&#xff1a;安装 Node.js步骤 2&#xff1a;安装 live - server步骤 3&#xff1a;使用 live - server 运行本地项目 2-Mac系统步骤 1&#xff1a;安装 Node.js步骤 2…...

c++中的一些控制符

控制符在<iomanip>头文件里 一、设置显示小数精度 &#xff1a;setprecision() float A3.1234&#xff1b; 默认有效位为6位&#xff0c;steprecision(3)→设置有效位为3位 【3.12】 可以与fixed搭配用&#xff0c;cout<<fixed<<setprecision(3)<&l…...

Go语言里面的堆跟栈 + new 和 make + 内存逃逸 + 闭包

在 Go 语言中&#xff0c;堆&#xff08;Heap&#xff09;和栈&#xff08;Stack&#xff09;是内存管理中的两个重要概念&#xff0c;它们在内存分配、数据存储和使用场景等方面存在明显差异。 栈&#xff08;Stack&#xff09; 栈是一种具有后进先出&#xff08;LIFO&#…...

蓝桥备赛(11)- 数据结构、算法与STL

一、数据结构 1.1 什么是数据结构&#xff1f; 在计算机科学中&#xff0c;数据结构是一种 数据组织、管理和存储的格式。它是相互之间存在一种 或多种特定关系的数据元素的集合。 ---> 通俗点&#xff0c;数据结构就是数据的组织形式 &#xff0c; 研究数据是用什么方…...

react 19版中路由react-router-dom v7版的使用

路由的安装&#xff1a; npm install react-router-dom在src目录下建一个router文件夹 在router文件夹里面建一个index.tsx index.tsx内容&#xff1a; import React from react; import {BrowserRouter as Router,Routes,Route,Link } from react-router-dom; import ManuLi…...

WPS工具栏添加Mathtype加载项

问题描述&#xff1a; 分别安装好WPS和MathType之后&#xff0c;WPS工具栏没直接显示MathType工具&#xff0c;或者是前期使用正常&#xff0c;由于WPS更新之后MathType工具消失&#xff0c;如下图 解决办法 将文件“MathType Commands 2016.dotm”和“MathPage.wll”从Matht…...

Tauri+React+Ant Design跨平台开发环境搭建指南

TauriReactAnt Design跨平台开发环境搭建指南 一、环境配置与工具链搭建 1.1 基础环境准备 必备组件&#xff1a; Rust工具链&#xff08;v1.77&#xff09;&#xff1a; curl --proto https --tlsv1.2 -sSf https://sh.rustup.rs | sh Node.js LTS&#xff08;v20.11.1&a…...

PDF转JPG(并去除多余的白边)

首先&#xff0c;手动下载一个软件&#xff08;poppler for Windows&#xff09;&#xff0c;下载地址&#xff1a;https://github.com/oschwartz10612/poppler-windows/releases/tag/v24.08.0-0 否则会出现以下错误&#xff1a; PDFInfoNotInstalledError: Unable to get pag…...

std::string的模拟实现

目录 string的构造函数 无参数的构造函数 根据字符串初始化 用n个ch字符初始化 用一个字符串的前n个初始化 拷贝构造 用另一个string对象的pos位置向后len的长度初始化 [ ]解引用重载 迭代器的实现 非const版本 const版本 扩容reserve和resize reserve resize p…...

wordpress自定the_category的输出结构

通过WordPress的过滤器the_category来自定义输出内容。方法很简单&#xff0c;但是很实用。以下是一个示例代码&#xff1a; function custom_the_category($thelist, $separator , $parents ) {// 获取当前文章的所有分类$categories get_the_category();if (empty($categ…...

doris: Oracle

Apache Doris JDBC Catalog 支持通过标准 JDBC 接口连接 Oracle 数据库。本文档介绍如何配置 Oracle 数据库连接。 使用须知​ 要连接到 Oracle 数据库&#xff0c;您需要 Oracle 19c, 18c, 12c, 11g 或 10g。 Oracle 数据库的 JDBC 驱动程序&#xff0c;您可以从 Maven 仓库…...

mysql中什么机制保证宕机数据恢复

MySQL 通过多种机制来保证在宕机或意外崩溃时数据的完整性和可恢复性。这些机制主要包括 事务日志、崩溃恢复 和 数据持久化 等。以下是 MySQL 中保证数据恢复的核心机制: 1. 事务日志(Transaction Log) 事务日志是 MySQL 实现数据恢复的核心机制之一,主要包括 Redo Log(…...

前端面试技术性场景题

87.场景面试之大数运算&#xff1a;超过js中number最大值的数怎么处理 在 JavaScript 中&#xff0c;Number.MAX_SAFE_INTEGER&#xff08;即 2^53 - 1&#xff0c;即 9007199254740991&#xff09;是能被安全表示的最大整数。超过此值时&#xff0c;普通的 Number 类型会出现…...

解决CentOS 8.5被恶意扫描的问题

CentOS 8 官方仓库已停止维护(EOL),导致一些常用依赖包如fail2ban 无法正常安装。 完整解决方案: 一、问题根源 CentOS 8 官方仓库已停更:2021 年底 CentOS 8 停止维护,默认仓库的包可能无法满足依赖关系。EPEL 仓库兼容性:EPEL 仓库可能未适配 CentOS 8.5 的旧版本依赖…...

探秘基带算法:从原理到5G时代的通信变革【四】Polar 编解码(二)

文章目录 2.3.3 极化编码巴氏参数与信道可靠性比特混合生成矩阵编码举例 2.3.4 极化译码最小单元译码串行抵消译码&#xff08;SC译码&#xff09;算法SCL译码算法 2.3.5 总结**Polar 码的优势****Polar 码的主要问题****Polar 码的应用前景** 2.3.6 **参考文档** 本博客为系列…...

机器学习准备工作

机器学习准备工作 机器学习概述常见算法动手实践 深度学习基础框架应用领域 数学基础线性代数概率论和统计学微积分 编程基础Python基础数据处理工具 项目实战入门1. Scikit-learn 示例项目2. TensorFlow/Keras 入门项目3. Kaggle 入门竞赛 进阶1. PyTorch 官方教程2. MMDetect…...

汽车智能钥匙中PKE低频天线的作用

PKE&#xff08;Passive Keyless Entry&#xff09;即被动式无钥匙进入系统&#xff0c;汽车智能钥匙中PKE低频天线在现代汽车的智能功能和安全保障方面发挥着关键作用&#xff0c;以下是其具体作用&#xff1a; 信号交互与身份认证 低频信号接收&#xff1a;当车主靠近车辆时…...

Codepen和tailwindcss 进行UI布局展示

html <html lang"zh"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>设备管理仪表盘</title><script src"https://cdn.tailw…...

准备好了数据集之后,如何在ubuntu22.04上训练一个yolov8模型。

在Ubuntu 22.04上训练YOLOv8模型的步骤如下&#xff1a; 1. 安装依赖 首先&#xff0c;确保系统已安装Python和必要的库。 sudo apt update sudo apt install python3-pip python3-venv2. 创建虚拟环境 创建并激活虚拟环境&#xff1a; python3 -m venv yolov8_env source…...

集合框架、Collection、list、ArrayList、Set、HashSet和LinkedHashSet、判断两个对象是否相等

DAY7.1 Java核心基础 集合框架 Java 中很重要的一个知识点&#xff0c;实际开发中使用的频录较高&#xff0c;Java 程序中必备的模块 集合就是长度可以改变&#xff0c;可以保存任意数据类型的动态数组 最上层是一组接口&#xff0c;接下来是接口的实现类&#xff0c;第三层…...

宝塔 Linux 计划任务中添加运行项目网站PHP任务-定时任务

一、指定php版运行&#xff0c; cd /www/wwwroot/www.xxx.com/ && /www/server/php/56/bin/php think timedtasks start >> /tmp/timedtasks.log 2>&1 二、不指定php版 cd /www/wwwroot/www.xxx.com/ && php think timedtasks start >> …...

JDK ZOOKEEPER KAFKA安装

JDK17下载安装 mkdir -p /usr/local/develop cd /usr/local/develop 将下载的包上传服务器指定路径 解压文件 tar -zxvf jdk-17.0.14_linux-x64_bin.tar.gz -C /usr/local/develop/ 修改文件夹名 mv /usr/local/develop/jdk-17.0.14 /usr/local/develop/java17 配置环境变量…...