Vue生命周期详细解析
前言
Vue.js作为当前最流行的前端框架之一,其生命周期钩子函数是每个Vue开发者必须掌握的核心概念。本文将全面解析Vue的生命周期,帮助开发者更好地理解Vue实例的创建、更新和销毁过程。
一、Vue生命周期概述
Vue实例从创建到销毁的整个过程被称为Vue的生命周期。在这个过程中,Vue提供了一系列的钩子函数(生命周期钩子),允许开发者在特定阶段添加自己的代码。
生命周期图示
图片来源官方
二、生命周期钩子函数详解
1. 创建阶段
beforeCreate
- 调用时机:实例初始化之后,数据观测(data observer)和event/watcher事件配置之前
- 特点:
- 此时无法访问到data、computed、methods等
- 常用于插件开发中执行一些初始化任务
beforeCreate() {console.log('beforeCreate:', this.message); // undefinedconsole.log('beforeCreate:', this.sayHello); // undefined
}
created
- 调用时机:实例创建完成后立即调用
- 特点:
- 可以访问data、computed、methods等
- 尚未挂载DOM,$el属性不可用
- 常用于异步数据请求
created() {console.log('created:', this.message); // 可以访问console.log('created:', this.sayHello()); // 可以调用console.log('created:', this.$el); // undefined
}
2. 挂载阶段
beforeMount
- 调用时机:在挂载开始之前被调用
- 特点:
- 模板编译完成,但尚未将模板渲染到页面
- 很少使用,了解即可
beforeMount() {console.log('beforeMount:', this.$el); // 原始的挂载元素
}
mounted
- 调用时机:实例被挂载后调用
- 特点:
- 可以访问到渲染后的DOM
- 常用于需要操作DOM的第三方库初始化
- 注意:不保证所有子组件也都一起被挂载
mounted() {console.log('mounted:', this.$el); // 渲染后的DOMthis.$nextTick(() => {// 仅在整个视图都被渲染之后才会运行的代码});
}
3. 更新阶段
beforeUpdate
- 调用时机:数据变化时,虚拟DOM重新渲染和打补丁之前
- 特点:
- 可以在更新前访问现有的DOM
- 适合在更新之前访问现有的DOM,比如手动移除已添加的事件监听器
beforeUpdate() {console.log('beforeUpdate:', this.message);
}
updated
- 调用时机:数据更改导致的虚拟DOM重新渲染和打补丁后
- 特点:
- 可以执行依赖于DOM的操作
- 注意:避免在此钩子中更改状态,可能会导致无限循环
- 不保证所有的子组件也都一起被重绘
updated() {console.log('updated:', this.message);this.$nextTick(() => {// 仅在整个视图都被重新渲染之后才会运行的代码});
}
4. 销毁阶段
beforeDestroy
- 调用时机:实例销毁之前
- 特点:
- 实例仍然完全可用
- 适合清除定时器、取消事件监听、取消订阅等清理工作
beforeDestroy() {console.log('beforeDestroy');clearInterval(this.timer);
}
destroyed
- 调用时机:实例销毁后
- 特点:
- 所有的事件监听器和子实例都被移除
- 很少使用,了解即可
destroyed() {console.log('destroyed');
}
三、特殊生命周期钩子
activated
- 使用场景:
<keep-alive>
缓存的组件激活时调用 - 特点:可用于重新获取数据或重置状态
activated() {console.log('组件被激活');
}
deactivated
- 使用场景:
<keep-alive>
缓存的组件停用时调用 - 特点:可用于保存状态或清除定时器
deactivated() {console.log('组件被停用');
}
errorCaptured
- 使用场景:捕获来自子孙组件的错误时调用
- 特点:
- 可以返回false阻止错误继续向上传播
- 可用于错误上报
errorCaptured(err, vm, info) {console.error('捕获到错误:', err);// 错误上报逻辑return false; // 阻止错误继续向上传播
}
四、生命周期使用场景总结
生命周期钩子 | 常见使用场景 |
---|---|
beforeCreate | 插件开发、初始化任务 |
created | 异步数据请求、初始化非DOM相关操作 |
beforeMount | 极少使用 |
mounted | DOM操作、第三方库初始化 |
beforeUpdate | 更新前访问现有DOM |
updated | 数据更新后的DOM操作 |
beforeDestroy | 清除定时器、取消事件监听、取消订阅 |
destroyed | 极少使用 |
activated | 缓存组件重新激活时的数据获取 |
deactivated | 缓存组件停用时的状态保存 |
五、注意事项
- 避免在生命周期钩子中使用箭头函数,这会改变this的指向
- 异步操作的影响:异步操作可能导致生命周期钩子的执行顺序不如预期
- 父子组件生命周期顺序:
- 父beforeCreate → 父created → 父beforeMount → 子beforeCreate → 子created → 子beforeMount → 子mounted → 父mounted
- 更新顺序:父beforeUpdate → 子beforeUpdate → 子updated → 父updated
六、总结
理解Vue生命周期对于开发高质量的Vue应用至关重要。通过合理利用生命周期钩子,我们可以在适当的时机执行代码,优化应用性能,处理各种边界情况。建议开发者在实际项目中多加练习,深入理解每个生命周期的特点和适用场景。
相关文章:

Vue生命周期详细解析
前言 Vue.js作为当前最流行的前端框架之一,其生命周期钩子函数是每个Vue开发者必须掌握的核心概念。本文将全面解析Vue的生命周期,帮助开发者更好地理解Vue实例的创建、更新和销毁过程。 一、Vue生命周期概述 Vue实例从创建到销毁的整个过程被称为Vue…...

基于c#,wpf,ef框架,sql server数据库,音乐播放器
详细视频: 【基于c#,wpf,ef框架,sql server数据库,音乐播放器。-哔哩哔哩】 https://b23.tv/ZqmOKJ5...

前端项目搭建集锦:vite、vue、react、antd、vant、ts、sass、eslint、prettier、浏览器扩展,开箱即用,附带项目搭建教程
前端项目搭建集锦:vite、vue、react、antd、vant、ts、sass、eslint、prettier、浏览器扩展,开箱即用,附带项目搭建教程 前言:一、Vue项目下载快速通道二、React项目下载快速通道三、BrowserPlugins项目下载快速通道四、项目搭建教…...
【C++游戏引擎开发】第21篇:基于物理渲染(PBR)——统计学解构材质与光影
引言 宏观现象:人眼观察到的材质表面特性(如金属的高光锐利、石膏的漫反射柔和),本质上是微观结构对光线的统计平均结果。 微观真相:任何看似平整的表面在放大后都呈现崎岖的微观几何。每个微表面(Microfacet)均为完美镜面,但大量微表面以不同朝向分布时,宏观上会表…...

什么是Maven
Maven的概念 Maven是一个一键式的自动化的构建工具。Maven 是 Apache 软件基金会组织维护的一款自动化构建工具,专注服务于Java 平台的项目构建和依赖管理。Maven 这个单词的本意是:专家,内行。Maven 是目前最流行的自动化构建工具࿰…...
强化学习复习,价值函数的推导——北大pdf p41(ppt75)(动手学也有)
我们经常看到强化学习中有求汇报期望 E E E,转化为价值函数(value function) V V V,策略的状态价值函数(State-Value function) V π V_π Vπ和动作价值函数(action-value function) Q π Q_π Qπ。还有提到通过将期望将消除…...

neo4j中节点内的名称显示不全解决办法(如何让label在节点上自动换行)
因为节点过多而且想让节点中所有文字都显示出来而放大节点尺寸 从neo4j中导出png,再转成PDF来查看时,要看清节点里面的文字就得放大5倍才行 在网上看了很多让里面文字换行的办法都不行 然后找到一个比较靠谱的办法是在要显示的标签内加换行符 但是我的节点上显示的是…...
day 32 学习笔记
文章目录 前言一、模版匹配的概念二、模版匹配方法 前言 通过今天的学习,我掌握了OpenCV中有关模版匹配和模版匹配方法的相关原理和操作 一、模版匹配的概念 模板匹配就是用模板图(通常是一个小图)在目标图像(通常是一个比模板图…...

【GIT】github中的仓库如何删除?
你可以按照以下步骤删除 GitHub 上的仓库(repository): 🚨 注意事项: ❗️删除仓库是不可恢复的操作,所有代码、issue、pull request、release 等内容都会被永久删除。 🧭 删除 GitHub 仓库步骤…...
使用Python将YOLO的XML标注文件转换为TXT文件格式
使用Python将YOLO的XML标注文件转换为TXT文件格式,并划分数据集 import xml.etree.ElementTree as ET import os from os import listdir, getcwd from os.path import join import random from shutil import copyfile from PIL import Image# 只要改下面的CLASSE…...
docker容器监控自动恢复
关于实现对docker容器监控以及自动恢复,这里介绍两种实现方案。 方案1: 实现思路: 找到(根据正则表达式)所有待监控的docker容器,此处筛选逻辑根据docker运行状态找到已停止(Exit)类…...
【农气项目】基于适宜度的产量预报
直接上干货(复制到开发工具即可运行的代码) 1. 适宜度模型及作物適宜度计算方法 2. 产量分离 3. 基于适宜度计算产量预报 1. 适宜度模型及作物適宜度计算方法 // 三基点温度配置private final double tempMin;private final double tempOpt;private f…...
1、AI及LLM基础:Python语法入门教程
Python语法入门教程 这是一份全面的Python语法入门教程,涵盖了注释、变量类型与操作符、逻辑运算、list和字符串、变量与集合、控制流和迭代、模块、类、继承、进阶等内容,通过详细的代码示例和解释,帮助大家快速熟悉Python语法。 文章目录 Python语法入门教程一、注释二…...

3台CentOS虚拟机部署 StarRocks 1 FE+ 3 BE集群
背景:公司最近业务数据量上去了,需要做一个漏斗分析功能,实时性要求较高,mysql已经已经不在适用,做了个大数据技术栈选型调研后,决定使用StarRocks StarRocks官网:StarRocks | A High-Performa…...
服务器上安装node
1.安装 下载安装包 https://nodejs.org/en/download 解压安装包 将安装包上传到/opt/software目录下 cd /opt/software tar -xzvf node-v16.14.2-linux-x64.tar.gz 将解压的文件夹移动到安装目录(/opt/nodejs)下 mv /opt/software/node-v16.14.2-linux-x64 /opt/nodejs …...
精益数据分析(20/126):解析经典数据分析框架,助力创业增长
精益数据分析(20/126):解析经典数据分析框架,助力创业增长 在创业和数据分析的学习道路上,每一次深入探索都可能为我们带来新的启发。今天,依旧带着和大家共同进步的想法,我们一起深入研读《精…...
9.策略模式:思考与解读
原文地址:策略模式:思考与解读 更多内容请关注:7.深入思考与解读设计模式 引言 你是否曾遇到过这样的情况:在一个系统中,有许多算法或策略,每种策略的实现逻辑相似,但在某些情况下需要进行替换和扩展&am…...

【HCIA】简易的两个VLAN分别使用DHCP分配IP
前言 之前我们通过 静态ip地址实现了Vlan间通信 ,现在我们添加一个常用的DHCP功能。 文章目录 前言1. 配置交换机2. 接口模式3. 全局模式后记修改记录 1. 配置交换机 首先,使用DHCP,需要先启动DHCP服务: [Huawei]dhcp enable I…...
【设计模式-4】深入理解设计模式:工厂模式详解
在软件开发中,对象的创建是一个基础但至关重要的环节。随着系统复杂度的增加,直接使用new关键字实例化对象会带来诸多问题,如代码耦合度高、难以扩展和维护等。工厂模式(Factory Pattern)作为一种创建型设计模式&#…...
Spring Boot 整合 JavaFX 核心知识点详解
1. 架构设计与集成模式 1.1 Spring Boot 与 JavaFX 的分层架构设计 Spring Boot 与 JavaFX 的整合需要精心设计的分层架构,以充分利用两个框架的优势。 标准分层架构 ┌────────────────────────────────────────────────…...
Spring MVC DispatcherServlet 的作用是什么? 它在整个请求处理流程中扮演了什么角色?为什么它是核心?
DispatcherServlet 是 Spring MVC 框架的绝对核心和灵魂。它扮演着前端控制器(Front Controller)的角色,是所有进入 Spring MVC 应用程序的 HTTP 请求的统一入口点和中央调度枢纽。 一、 DispatcherServlet 的核心作用和职责: 请…...
亚马逊英国站FBA费用重构:轻小商品迎红利期,跨境卖家如何抢占先机?
一、政策背景:成本优化成平台与卖家共同诉求 2024年4月,亚马逊英国站(Amazon.co.uk)发布近三年来力度最大的FBA费用调整方案,标志着英国电商市场正式进入精细化成本管理时代。这一决策背后,是多重因素的叠…...
Redis在.NET平台中的各种应用场景
关键点总结 连接管理:所有示例都使用ConnectionMultiplexer来管理Redis连接,它是线程安全的,应该在整个应用程序中重用。 键设计:良好的键命名规范很重要,通常使用冒号分隔的层次结构(如page:home:pv)。 数据序列化&…...
近几年字节测开部分面试题整理
文章目录 前言一、面试问题1. 在浏览器url上写一个地址,请描述一下网络方面有哪些变化2. 堆栈数据存储位置3. HTTP POST请求支持的数据格式4. 缩容要注意些什么?5. Python中元组、数组、list和数组的区别6. Python中is和的区别7. HTTP与HTTPS8. 已知两个…...

艾蒙顿桌面app下载-Emotn UI下载安装-emotn ui官方tv版安卓固件
在智能电视桌面应用的领域里,Emotn UI 凭借其简洁无广告、可自定义等特点,赢得了不少用户的关注。然而,小编深入了解后发现了一款更好用的电视桌面——乐看家桌面在诸多方面更具优势,能为你带来更优质的大屏体验。 乐看家桌面内置…...

3、ArkTS语言介绍
目录 基础知识函数函数声明可选参数Rest参数返回类型箭头函数(又名Lambda函数)闭包 类字段字段初始化getter和setter继承父类访问方法重写方法重载签名可见性修饰符(Public、Private、protected) 基础知识 ArkTS是一种为构建高性…...

修改了Element UI中组件的样式,打包后样式丢失
修改了Element UI中组件的样式,在本地运行没有问题,但是打包到线上发现样式丢失(样式全部不生效、或者有一部分生效,一部分不生效),问题在于css的加载顺序导致代码编译后样式被覆盖了, 解决办法…...
Linux GPIO驱动开发实战:Poll与异步通知双机制详解
1. 引言 在嵌入式Linux开发中,GPIO按键驱动是最基础也最典型的案例之一。本文将基于一个支持poll和异步通知双机制的GPIO驱动框架,深入剖析以下核心内容: GPIO中断与防抖处理环形缓冲区设计Poll机制实现异步通知(SIGIO)实现应用层交互方式 …...

【springsecurity oauth2授权中心】jwt令牌更换成自省令牌 OpaqueToken P4
前言 前面实现了授权中心授权,客户端拿到access_token后就能请求资源服务器接口 权限的校验都是在资源服务器上进行的,授权服务器颁发的access_token有限期是2小时,也就是说在2小时之内,不管授权服务器那边用户的权限如何变更都…...

诱骗协议芯片支持PD2.0/3.0/3.1/PPS协议,支持使用一个Type-C与电脑传输数据和快充取电功能
快充是由充电器端的充电协议和设备端的取电协议进行握手通讯进行协议识别来完成的,当充电器端的充电协议和设备端的取电协议握手成功后,设备会向充电器发送电压请求,充电器会根据设备的需求发送合适的电压给设备快速供电。 设备如何选择快充…...