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

Vue 2 生命周期详解

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.kler.cn/news/303901.html

相关文章:

  • 在Ubuntu 18.04上安装Nginx的方法
  • Probabilistic Embeddings for Cross-Modal Retrieval 论文阅读
  • C++string模拟实现
  • Llama Factory :百种以上语言模型的统一高效微调框架
  • UDP聊天室项目
  • 若依系统(Security)增加微信小程序登录(自定义登录)
  • nginx部署时的路径配置问题
  • 网络安全要点总结
  • 第四届长城杯-misc
  • 如何使用命令安装android的.aab包
  • Cesium 问题:视角漫游时添加的无人机模型飞行时有抖动
  • 隧道代理的原理及其挑选指南
  • 828华为云征文 | Flexus X实例在华为云EulerOS环境中部署堡垒机Jumpserver的详细指南
  • JS获取页面中video标签视频的封面和时长
  • 代理IP池纯净度对数据抓取有影响吗?
  • ​2024年最新python教程全套,现在分享给大家(python全栈)
  • 2024年最新软件测试面试题【附文档答案】
  • websim.ai 体验过程+感受
  • 《创新电力巡检,机器人铸就安全高效未来》
  • Windows编译MongoDB的C++库,并使用Qt调用
  • centos8构建nginx1.27.1+BoringSSL+http3+lua+openresty
  • 如何在 Vue 3 中使用 Element Plus
  • 3.3k star开源的Notepad++文本编辑器替代品,跨平台
  • 从底层原理上解释 clickhouse 保证完全的幂等性
  • 皮皮鲁周边商品网络销售系统的设计与实现---附源码74752
  • Android前台服务如何在后台启动activity?
  • Leetcode 每日一题:Word Ladder
  • Autosar模式管理实战系列-COMM模块状态机及重要函数讲解
  • neo4j docker 运行4.35 community 版本失败
  • 氢能源多旋翼无人机技术详解