Vue的父子组件生命周期钩子函数执行顺序 ?

Vue的父子组件生命周期钩子函数的执行顺序可以清晰地分为几个阶段,包括加载渲染过程、更新过程以及销毁过程。以下是详细的解释:

加载渲染过程

  1. 父组件的beforeCreate:在父组件实例被创建之前调用。
  2. 父组件的created:在父组件实例创建完成后调用。
  3. 父组件的beforeMount:在父组件开始挂载之前调用,此时模板已经编译成虚拟DOM。
  4. 子组件的beforeCreate和created:在父组件的beforeMount钩子内,子组件的beforeCreate和created钩子依次被调用。
  5. 子组件的beforeMount和mounted:子组件的虚拟DOM挂载成真实DOM后,mounted钩子被调用。
  6. 父组件的mounted:在子组件挂载完成后,父组件的mounted钩子被调用,表示整个父组件及其子组件都已经挂载完成。

更新过程(当数据变化时)

  1. 父组件的beforeUpdate:在父组件的虚拟DOM重新渲染和打补丁之前调用。
  2. 子组件的beforeUpdate和updated:子组件根据新的数据重新渲染和更新。
  3. 父组件的updated:在父组件的DOM更新后调用。

销毁过程

  1. 父组件的beforeDestroy:在父组件销毁之前调用,用于执行清理任务。
  2. 子组件的beforeDestroy和destroyed:子组件在父组件销毁之前先进行销毁。
  3. 父组件的destroyed:父组件及其所有子组件都已经被销毁。

总结

这个顺序确保了Vue组件的层次结构在生命周期中的正确管理。在加载渲染过程中,父组件的生命周期钩子会在子组件的生命周期钩子之前触发,而在销毁过程中,子组件会先被销毁,然后才是父组件。同样,在更新过程中,父组件的更新会触发子组件的重新渲染,但父组件的更新钩子会在子组件的更新钩子之后触发。这些生命周期钩子函数顺序可以帮助开发者在合适的时机执行相应的逻辑。

相关推荐
10年前端老司机3 小时前
React无限级菜单:一个项目带你突破技术瓶颈
前端·javascript·react.js
阿芯爱编程7 小时前
2025前端面试题
前端·面试
前端小趴菜059 小时前
React - createPortal
前端·vue.js·react.js
晓13139 小时前
JavaScript加强篇——第四章 日期对象与DOM节点(基础)
开发语言·前端·javascript
菜包eo9 小时前
如何设置直播间的观看门槛,让直播间安全有效地运行?
前端·安全·音视频
烛阴10 小时前
JavaScript函数参数完全指南:从基础到高级技巧,一网打尽!
前端·javascript
chao_78911 小时前
frame 与新窗口切换操作【selenium 】
前端·javascript·css·selenium·测试工具·自动化·html
天蓝色的鱼鱼11 小时前
从零实现浏览器摄像头控制与视频录制:基于原生 JavaScript 的完整指南
前端·javascript
三原11 小时前
7000块帮朋友做了2个小程序加一个后台管理系统,值不值?
前端·vue.js·微信小程序
popoxf12 小时前
在新版本的微信开发者工具中使用npm包
前端·npm·node.js