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实例生命周期各个阶段的具体说明和对应的代码示例,希望对你有所帮助。

相关推荐
kngines几秒前
【Node.js从 0 到 1:入门实战与项目驱动】1.2 Node.js 的核心优势(非阻塞 I/O、事件驱动、单线程模型)
开发语言·javascript·node.js
奈斯。zs9 分钟前
JavaWeb02——基础标签及样式(黑马视频笔记)
前端·笔记·html
白仑色10 分钟前
AJAX表单验证项目实战:实时用户名检查
前端·javascript·ajax·表单验证·py
卸载引擎23 分钟前
【Electron】electron-vite中基于electron-builder与electron-updater实现程序远程自动更新,附源码
前端·javascript·electron
Robbie丨Yang40 分钟前
CSS 工作原理
前端·css
酒渣44 分钟前
css动态样式
前端·css
天下无贼!1 小时前
【轮播图】H5端轮播图、横向滑动、划屏效果实现方案——Vue3+CSS position/CSS scroller
javascript·css·vue.js·vue
转转技术团队1 小时前
从“v我50”到“疯狂星期四”:HTTPS如何用47天寿命的证书挡住中间人
前端
zeqinjie1 小时前
Flutter 使用 AI Cursor 快速完成一个图表封装【提效】
前端·flutter
真上帝的左手1 小时前
24. 前端-js框架-Vue
前端·javascript·vue.js