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

相关推荐
时光追逐者9 分钟前
一个基于 .NET + Vue 实现的通用权限管理平台(RBAC模式),前后端分离模式,开箱即用!
前端·vue.js·c#·.net·.net core
Aotman_11 分钟前
Vue el-table 表尾合计行
前端·javascript·vue.js·elementui·前端框架·ecmascript
编程猪猪侠14 分钟前
Vue3 + Ant Design Vue 实现 Table 表格嵌套 Radio 单选框
javascript·vue.js·anti-design-vue
phltxy17 分钟前
Vue3 + Vite:从入门到实战——核心指令全解析
vue.js·vue
静小谢18 分钟前
vue3实现语言切换vue-i18n
前端·javascript·vue.js
Highcharts.js19 分钟前
如何使用Highcharts Flutter的官方使用文档
javascript·flutter·开发文档·highcharts
东东51622 分钟前
资产管理信息系统ssm+vue
前端·javascript·vue.js
森爱。24 分钟前
web开发全家桶(django+前端+数据库)
前端·python·django
骆驼爱记录27 分钟前
Word侧边页码设置全攻略
前端·自动化·word·excel·wps·新人首发
利刃大大30 分钟前
【Vue】声明式导航与传参 && 编程式导航与传参 && 嵌套与守卫
javascript·vue.js·ecmascript