Vue 2 生命周期详解

embedded/2024/12/21 23:25:36/

Vue 2 的生命周期是指 Vue 实例从创建到销毁的整个过程。在这个过程中,Vue 提供了多个生命周期钩子,允许我们在不同阶段执行代码。以下是 Vue 2 生命周期的详细解析:

1. 创建阶段 (Creation)

  • beforeCreate: 在实例初始化之后,数据观测和事件/侦听器配置之前被调用。在这一步,data 属性和 methods 方法还未被初始化,因此不能访问。
  • created: 实例已经创建完成,数据观测、属性和方法的运算以及事件/侦听器的配置已经完成。然而,挂载阶段还没开始,$el 属性目前不可见。

2. 挂载阶段 (Mounting)

  • beforeMount: 在挂载开始之前被调用,相关的 render 函数首次被调用,模板开始编译,但 $el 还未挂载到实例上。
  • mounted: 实例被挂载到 DOM 后调用。此时,可以访问到 $el 属性,并且模板中的 HTML 已经被渲染到页面上。这个阶段适合执行 DOM 操作或者执行依赖于 DOM 的操作,如发送 AJAX 请求或者绑定自定义事件。

3. 更新阶段 (Updating)

  • beforeUpdate: 在数据变化导致虚拟 DOM 重新渲染和打补丁之前调用。此时,可以在这个钩子中进一步地更改状态,不会导致无限循环的调用。
  • updated: 由于数据更改导致的虚拟 DOM 重新渲染和打补丁之后调用。调用时,组件 DOM 已经更新,可以执行依赖于最新 DOM 的操作。

4. 销毁阶段 (Destruction)

  • beforeDestroy: 在实例销毁之前调用。实例仍然完全可用,在这个生命周期钩子中,可以执行清理工作,如清除定时器、移除自定义事件监听等。
  • destroyed: 实例销毁后调用。调用后,所有的事件监听器会被移除,所有的子实例也会被销毁。

5. 特殊钩子 (Special Hooks)

  • activated: 仅在 keep-alive 组件中生效,当组件被激活时调用。
  • deactivated: 仅在 keep-alive 组件中生效,当组件被停用时调用。

代码示例

new Vue({data: {a: 1},beforeCreate() {console.log('beforeCreate: 数据和方法还未初始化');},created() {console.log('created: 数据和方法已初始化,但 DOM 还未挂载');},beforeMount() {console.log('beforeMount: 模板编译完成,但 DOM 还未挂载');},mounted() {console.log('mounted: DOM 已挂载,可以执行 DOM 操作');},beforeUpdate() {console.log('beforeUpdate: 数据更新,DOM 未渲染');},updated() {console.log('updated: 数据更新,DOM 已渲染');},beforeDestroy() {console.log('beforeDestroy: 实例销毁前,可以进行清理操作');},destroyed() {console.log('destroyed: 实例销毁后');}
});

总结

理解 Vue 2 的生命周期对于开发者来说非常重要,它可以帮助我们在合适的时机进行数据获取、事件绑定、资源清理等操作。通过合理使用生命周期钩子,可以使我们的 Vue 应用更加高效和稳定。


http://www.ppmy.cn/embedded/111375.html

相关文章

Llama Factory :百种以上语言模型的统一高效微调框架

人工智能咨询培训老师叶梓 转载标明出处 大模型适应到特定下游任务时,传统的全参数微调方法成本高昂,因此,研究者们一直在探索更高效的微调技术。由北京航空航天大学和北京大学的研究团队提出了一个名为Llama Factory的统一框架,…

数据结构——单链表基本操作的实现

前言 参考 该部分知识参考于《数据结构(C语言版 第2版)》29 ~ 36页 注意 这里的ElemType是以Book类型的数据作为举例,如果需要更改可以自行改变! 🌈每一个清晨,都是世界对你说的最温柔的早安&#xff…

在docker中安装 zendesk/maxwell 失败,解决方法

文章目录 1、拉取镜像失败2、一键设置镜像加速:修改文件 /etc/docker/daemon.json(如果不存在则创建)3、保存好之后 执行以下两条命令 1、拉取镜像失败 [rootlocalhost docker]# docker pull zendesk/maxwell Using default tag: latest Err…

vue事件修饰符

参考 https://cn.vuejs.org/guide/essentials/event-handling.html#event-modifiers 常用事件修饰符 .stop.prevent.self.capture.once.passive示例 阻止默认事件 使用.prevent属性(推荐) <script> export de

【计算机网络】HTTP相关问题与解答

此篇文章内容会不定期更新&#xff0c;仅作为学习过程中的笔记记录 目录 一、HTTP请求和响应报文是怎样的&#xff1f; 1、请求报文 2、响应报文 二、HTTP请求方法有哪些&#xff1f; GET HEAD POST PUT DELETE PATCH OPTIONS TRACE CONNECT 三、GET请求与POST请…

Loki 分布式日志中心服务

目录 Loki 是什么 Loki 配置文件介绍 Loki 安装 Promtail 配置文件介绍 Promtail 安装 Loki 整合 Grafana Loki 是什么 Loki 是一个专为日志聚合和查询设计的开源分布式日志管理系统&#xff0c;由 Grafana Labs 开发。它与 Prometheus 类似&#xff0c;但用于处理日志&a…

软件可维护性因素例题

答案&#xff1a;C 知识点&#xff1a; 系统可维护性因素决定 可理解性 可测试性 可修改性 选项C可移植性错误

从底层原理上解释 clickhouse 保证完全的幂等性

在分布式系统中&#xff0c;幂等性是指某个操作被多次执行&#xff0c;其效果和结果应该和执行一次相同。ClickHouse作为一个高效的OLAP数据库&#xff0c;在其底层架构和查询引擎中&#xff0c;通过多个机制和策略来确保操作的幂等性。具体来说&#xff0c;ClickHouse的幂等性…