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 中的 mounted 和 updated 生命周期钩子。
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开头。 - 使用有意义的名称,如
useFetchData、useLocalStorage。
4.2 单一职责
- 每个 Hook 只负责一个功能。
- 避免在 Hook 中处理过多逻辑。
4.3 依赖管理
- 明确指定
useEffect的依赖项,避免不必要的重复执行。 - 使用
watch或computed处理复杂依赖。
五、性能优化
5.1 减少重复渲染
- 使用
memo或computed缓存计算结果。 - 避免在渲染函数中创建新对象或函数。
5.2 懒加载 Hooks
- 使用
defineAsyncComponent异步加载组件。 - 将 Hooks 逻辑拆分为独立模块,按需加载。
六、Hooks 与 Class API 对比
| 特性 | Hooks API | Class API |
|---|---|---|
| 代码简洁性 | 高 | 低 |
| 逻辑复用 | 方便 | 依赖混入 |
| 类型支持 | 优秀 | 一般 |
| 学习曲线 | 较低 | 较高 |
| 性能优化 | 灵活 | 依赖生命周期 |
七、未来展望
- 生态扩展:更多官方和社区提供的 Hooks。
- 工具支持:更好的 DevTools 集成。
- 性能优化:更高效的渲染机制。
八、完整示例
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 深度解析:从原理到实践 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家!点我试试!! 文章目录 Vue Hooks 深度解析:从原理到实践一、背景…...
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
制作好差分包,使用adb线刷模式验证ota升级,出现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++中的无锁编程
引言 在当今多核处理器普及的时代,并发编程已成为高性能应用程序开发的关键技术。传统的基于锁的同步机制虽然使用简单,但往往会带来性能瓶颈和死锁风险。无锁编程(Lock-Free Programming)作为一种先进的并发编程范式,…...
7. 机器人记录数据集(具身智能机器人套件)
1. 树莓派启动机器人 conda activate lerobotpython lerobot/scripts/control_robot.py \--robot.typelekiwi \--control.typeremote_robot2. huggingface平台配置 huggingface官网 注册登录申请token(要有写权限)安装客户端 # 安装 pip install -U …...
设计模式 + java8方法引用 实现任意表的过滤器
会用到下面2个依赖,原因是在今天的案例中,我想在我代码中使用上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)
注意:复现代码时,确保 VS2022 使用 C17/20 标准以支持现代特性。 抽象与实现的解耦之道 1. 模式定义与用途 核心思想 桥接模式:将抽象部分与实现部分分离,使二者可以独立变化。关键用途: 1.拆分复杂继承…...
Html常用代码
Html常用代码 文章目录 Html常用代码1-常用的Html代码1-Html模板 2-快速部署Live-Server1-Windows系统步骤 1:安装 Node.js步骤 2:安装 live - server步骤 3:使用 live - server 运行本地项目 2-Mac系统步骤 1:安装 Node.js步骤 2…...
c++中的一些控制符
控制符在<iomanip>头文件里 一、设置显示小数精度 :setprecision() float A3.1234; 默认有效位为6位,steprecision(3)→设置有效位为3位 【3.12】 可以与fixed搭配用,cout<<fixed<<setprecision(3)<&l…...
Go语言里面的堆跟栈 + new 和 make + 内存逃逸 + 闭包
在 Go 语言中,堆(Heap)和栈(Stack)是内存管理中的两个重要概念,它们在内存分配、数据存储和使用场景等方面存在明显差异。 栈(Stack) 栈是一种具有后进先出(LIFO&#…...
蓝桥备赛(11)- 数据结构、算法与STL
一、数据结构 1.1 什么是数据结构? 在计算机科学中,数据结构是一种 数据组织、管理和存储的格式。它是相互之间存在一种 或多种特定关系的数据元素的集合。 ---> 通俗点,数据结构就是数据的组织形式 , 研究数据是用什么方…...
react 19版中路由react-router-dom v7版的使用
路由的安装: npm install react-router-dom在src目录下建一个router文件夹 在router文件夹里面建一个index.tsx index.tsx内容: import React from react; import {BrowserRouter as Router,Routes,Route,Link } from react-router-dom; import ManuLi…...
WPS工具栏添加Mathtype加载项
问题描述: 分别安装好WPS和MathType之后,WPS工具栏没直接显示MathType工具,或者是前期使用正常,由于WPS更新之后MathType工具消失,如下图 解决办法 将文件“MathType Commands 2016.dotm”和“MathPage.wll”从Matht…...
Tauri+React+Ant Design跨平台开发环境搭建指南
TauriReactAnt Design跨平台开发环境搭建指南 一、环境配置与工具链搭建 1.1 基础环境准备 必备组件: Rust工具链(v1.77): curl --proto https --tlsv1.2 -sSf https://sh.rustup.rs | sh Node.js LTS(v20.11.1&a…...
PDF转JPG(并去除多余的白边)
首先,手动下载一个软件(poppler for Windows),下载地址:https://github.com/oschwartz10612/poppler-windows/releases/tag/v24.08.0-0 否则会出现以下错误: 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来自定义输出内容。方法很简单,但是很实用。以下是一个示例代码: function custom_the_category($thelist, $separator , $parents ) {// 获取当前文章的所有分类$categories get_the_category();if (empty($categ…...
doris: Oracle
Apache Doris JDBC Catalog 支持通过标准 JDBC 接口连接 Oracle 数据库。本文档介绍如何配置 Oracle 数据库连接。 使用须知 要连接到 Oracle 数据库,您需要 Oracle 19c, 18c, 12c, 11g 或 10g。 Oracle 数据库的 JDBC 驱动程序,您可以从 Maven 仓库…...
mysql中什么机制保证宕机数据恢复
MySQL 通过多种机制来保证在宕机或意外崩溃时数据的完整性和可恢复性。这些机制主要包括 事务日志、崩溃恢复 和 数据持久化 等。以下是 MySQL 中保证数据恢复的核心机制: 1. 事务日志(Transaction Log) 事务日志是 MySQL 实现数据恢复的核心机制之一,主要包括 Redo Log(…...
前端面试技术性场景题
87.场景面试之大数运算:超过js中number最大值的数怎么处理 在 JavaScript 中,Number.MAX_SAFE_INTEGER(即 2^53 - 1,即 9007199254740991)是能被安全表示的最大整数。超过此值时,普通的 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 极化译码最小单元译码串行抵消译码(SC译码)算法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(Passive Keyless Entry)即被动式无钥匙进入系统,汽车智能钥匙中PKE低频天线在现代汽车的智能功能和安全保障方面发挥着关键作用,以下是其具体作用: 信号交互与身份认证 低频信号接收:当车主靠近车辆时…...
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模型的步骤如下: 1. 安装依赖 首先,确保系统已安装Python和必要的库。 sudo apt update sudo apt install python3-pip python3-venv2. 创建虚拟环境 创建并激活虚拟环境: python3 -m venv yolov8_env source…...
集合框架、Collection、list、ArrayList、Set、HashSet和LinkedHashSet、判断两个对象是否相等
DAY7.1 Java核心基础 集合框架 Java 中很重要的一个知识点,实际开发中使用的频录较高,Java 程序中必备的模块 集合就是长度可以改变,可以保存任意数据类型的动态数组 最上层是一组接口,接下来是接口的实现类,第三层…...
宝塔 Linux 计划任务中添加运行项目网站PHP任务-定时任务
一、指定php版运行, 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 配置环境变量…...
