vue每个阶段的生命周期做了什么

Vue 实例的生命周期可以分为创建阶段、挂载阶段、更新阶段和销毁阶段。下面是每个阶段具体干了什么的说明和对应的代码示例:

创建阶段

  1. beforeCreate

    • 此阶段在实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配置之前被调用。
    • 主要用于在实例初始化之后,但是在实例准备好之前执行一些逻辑。

    new Vue({
    beforeCreate: function () {
    console.log('Before create hook');
    }
    });

  2. created

    • 在实例创建完成后被立即调用。
    • 在这一步,实例已经完成了 data 的观测和属性方法的运算,但是挂载阶段还没开始。

    new Vue({
    created: function () {
    console.log('Created hook');
    }
    });

挂载阶段

  1. beforeMount

    • 在挂载开始之前被调用。
    • 相关的render函数首次被调用。

    new Vue({
    beforeMount: function () {
    console.log('Before mount hook');
    }
    });

  2. mounted

    • 在实例被挂载到DOM后调用。
    • 如果根实例挂载到了一个文档内的元素上,当 mounted 被调用时 vm.$el 也在文档内。

    new Vue({
    mounted: function () {
    console.log('Mounted hook');
    }
    });

更新阶段

  1. beforeUpdate

    • 数据更新时调用,发生在虚拟 DOM 重新渲染和打补丁之前。
    • 可以在该钩子中进一步地更改状态,不会触发附加的重渲染过程。

    new Vue({
    beforeUpdate: function () {
    console.log('Before update hook');
    }
    });

  2. updated

    • 由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用该钩子。

    new Vue({
    updated: function () {
    console.log('Updated hook');
    }
    });

销毁阶段

  1. beforeDestroy

    • 在实例销毁之前调用。实例仍然完全可用。

    new Vue({
    beforeDestroy: function () {
    console.log('Before destroy hook');
    }
    });

  2. destroyed

    • 在实例销毁后调用。此时,实例的所有指令都已解绑,所有的事件监听器已移除,所有的子实例也已被销毁。

    new Vue({
    destroyed: function () {
    console.log('Destroyed hook');
    }
    });

以上是Vue实例生命周期各个阶段的具体说明和对应的代码示例,希望对你有所帮助。

相关推荐
辰风沐阳5 分钟前
JavaScript 的宏任务和微任务
javascript
跳动的梦想家h36 分钟前
环境配置 + AI 提效双管齐下
java·vue.js·spring
夏幻灵1 小时前
HTML5里最常用的十大标签
前端·html·html5
冰暮流星1 小时前
javascript之二重循环练习
开发语言·javascript·数据库
Mr Xu_1 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝1 小时前
RBAC前端架构-01:项目初始化
前端·架构
程序员agions1 小时前
2026年,微前端终于“死“了
前端·状态模式
万岳科技系统开发1 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
程序员猫哥_2 小时前
HTML 生成网页工具推荐:从手写代码到 AI 自动生成网页的进化路径
前端·人工智能·html
龙飞052 小时前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl