Vue的生命周期解析(学习中)

本文详细阐述了Vue.js实例从创建到销毁的生命周期过程,介绍了各阶段的钩子函数及其用途,如数据初始化、DOM操作、资源清理等,帮助开发者更好地理解和利用Vue的生命周期管理。
摘要由CSDN通过智能技术生成

Vue的生命周期可以被理解为一个Vue实例从诞生到销毁的过程。在这个过程中,Vue实例会经历一系列的阶段,每个阶段都有相应的钩子函数。这些钩子函数就像是一些特定的时间点,允许你在这些时间点执行自定义的逻辑。

一、创建阶段

这是Vue实例的开始阶段,包括beforeCreatecreated两个钩子函数。

1.beforeCreate

在这个阶段,Vue实例已经被创建,但是它的数据和事件还没有被初始化。也就是说,你无法在beforeCreate钩子函数中访问到datamethods。这个阶段通常用于进行一些不依赖于数据和事件的初始化操作。例如,可以在这个阶段进行一些全局设置,或者初始化一些插件。但是,由于beforeCreate阶段发生在数据和事件初始化之前,所以你无法在这个阶段进行数据操作或事件监听。

2.created

这是Vue生命周期中的一个重要阶段,它在Vue实例被创建后立即被调用。在这个阶段,Vue实例的数据和事件已经被初始化,因此可以在created钩子函数中访问和操作它们。

二、挂载阶段

Vue的挂载阶段是Vue实例从虚拟DOM到真实DOM的过程。

1.beforeMount

它发生在Vue实例的模板已经编译完成,但还未将编译后的内容渲染到DOM中的时候。也就是说,这个阶段是Vue实例的虚拟DOM已经准备好,但还未真正挂载到页面的DOM中。

beforeMount阶段,你可以进行一些准备工作,但由于DOM还没有被创建,所以无法进行DOM操作。这个阶段可以看作是Vue实例从数据到视图的转换过程的一个关键节点,它标志着Vue实例即将进入到挂载阶段。

2.mounted

它发生在Vue实例的模板已经被渲染并挂载到DOM中之后。也就是说,此时Vue实例的虚拟DOM已经与真实DOM进行了关联,你可以在这个阶段进行DOM操作。以下是mounted钩子函数的一些常见用途:

  1. 获取DOM元素:在mounted阶段,可以获取到DOM元素,例如通过document.getElementByIdthis.$refs来获取DOM元素。

  2. 添加DOM事件监听器:可以在mounted阶段添加DOM事件监听器,例如监听window对象的resize事件或元素的click事件。

  3. 进行DOM操作:可以在mounted阶段进行DOM操作,例如修改DOM元素的样式或内容。

  4. 发送HTTP请求:你可以在mounted阶段发送HTTP请求获取数据,并将获取到的数据保存到data中,以供组件中使用。

三、更新阶段

1.beforeUpdate
它在Vue实例的数据发生变化,但页面还未重新渲染的时候被调用。也就是说,此时Vue实例的数据已经更新,但DOM还没有进行重新渲染。

在beforeUpdate阶段,可以进行一些数据更新前的操作,例如保存当前数据、获取最新数据等。但是,需要注意的是,beforeUpdate是在数据更新后虽然没立即更新数据,但是DOM中的数据会改变,这是Vue双向数据绑定的作用。

2.update

它在Vue实例的数据已经更新,并且页面已经完成重新渲染的时候被调用。也就是说,此时Vue实例的虚拟DOM已经重新渲染并打补丁到真实DOM。

updated阶段,你可以进行一些DOM操作,例如获取DOM元素、添加DOM事件监听器、进行DOM操作等。这是因为在这个阶段,DOM已经根据最新的数据进行了更新,所以可以安全地进行依赖于DOM的操作。

需要注意的是,updated钩子函数并不会在初始化渲染的时候被调用,它只会在数据发生变化并导致视图更新的时候被调用。此外,如果你在updated钩子函数中改变数据,可能会导致无限循环的更新,所以通常不建议在这个阶段改变数据。

四、销毁阶段

1.beforeDestroy

它在Vue实例即将被销毁之前被调用。在这个阶段,Vue实例仍然完全可用,所有的数据、事件和子组件都还在。

以下是beforeDestroy钩子函数的一些常见用途:

  1. 清理定时器:如果在组件中使用了定时器(例如setTimeoutsetInterval),你可以在beforeDestroy阶段清理这些定时器,以防止它们在组件销毁后继续运行。

  2. 取消事件监听:如果在组件中添加了事件监听器(例如addEventListener),你可以在beforeDestroy阶段取消这些事件监听,以防止它们在组件销毁后继续触发。

  3. 清理子组件和自定义事件:可以在beforeDestroy阶段清理子组件和自定义事件,以确保它们在组件销毁后不会留下任何副作用。

2.destroyed

它在Vue实例被完全销毁之后被调用。在这个阶段,Vue实例已经与其它实例的连接被清理,所有的指令及事件监听器也已经被解绑。

以下是destroyed钩子函数的一些常见用途:

  1. 清理工作:在destroyed阶段,可以进行一些清理工作,例如取消定时器、移除事件监听器、删除子组件等。这是因为在这个阶段,Vue实例已经被销毁,所有的事件监听器已经被移除,所有的子实例也已经被销毁。

  2. 释放资源:可以在destroyed阶段释放一些占用的资源,例如关闭数据库连接、释放内存等。这是因为在这个阶段,Vue实例已经被销毁,不再需要这些资源。

  • 17
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值