Vue 3 生命周期和生命周期函数

Vue.js 是一个用于构建用户界面的渐进式框架。随着 Vue 3 的发布,它引入了许多新的功能和改进,包括更灵活和性能更高的生命周期管理。在这份文档中,我们将详细介绍 Vue 3 的生命周期和相关生命周期函数。

一、生命周期概述

Vue 实例在其生命周期内经过一系列的初始化步骤,例如设置数据观测、编译模板、挂载实例到 DOM 以及在数据变化时更新 DOM。通过生命周期钩子,我们可以在这些步骤中执行自定义的操作。

二、生命周期图示

三、生命周期函数

以下是 Vue 3 中常用的生命周期函数以及它们的调用时机:

  1. beforeCreate

    • 在实例初始化之后,数据观测 (data observer) 和事件配置 (event setup) 之前调用。
    • 此时,组件实例的属性如 datacomputedmethods 尚未初始化。
  2. created

    • 在实例创建完成后被立即调用。
    • 在这一步,实例已完成数据观测、属性和方法的初始化,但还没有开始模板编译、挂载 DOM。
  3. beforeMount

    • 在挂载开始之前被调用:相关的 render 函数首次被调用。
    • 此时,虚拟 DOM 已经创建并渲染为真实 DOM,但尚未插入文档中。
  4. mounted

    • 在挂载完成后被调用。
    • 组件已经被挂载,el 属性可以访问到真实 DOM 元素。
  5. beforeUpdate

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

    • 由于数据变化导致的虚拟 DOM 重新渲染和打补丁完成之后调用。
    • 调用时,组件 DOM 已经更新。
  7. beforeUnmount

    • 在组件实例卸载之前调用。
    • 适用于清理工作,例如清楚定时器、取消订阅等。
  8. unmounted

    • 组件实例卸载后调用。
    • 实例已被销毁,所有的事件监听器被移除,所有的子实例也被销毁。

四、示例代码

下面是一个简单的 Vue 3 组件示例,展示了如何使用生命周期钩子:

javascript 复制代码
<template>
  <div>
    <h1>{{ message }}</h1>
  </div>
</template>

<script>
export default {
  data() {
    return {
      message: 'Hello, Vue 3!'
    };
  },
  beforeCreate() {
    console.log('beforeCreate');
  },
  created() {
    console.log('created');
  },
  beforeMount() {
    console.log('beforeMount');
  },
  mounted() {
    console.log('mounted');
  },
  beforeUpdate() {
    console.log('beforeUpdate');
  },
  updated() {
    console.log('updated');
  },
  beforeUnmount() {
    console.log('beforeUnmount');
  },
  unmounted() {
    console.log('unmounted');
  }
};
</script>

在这个示例中,每个生命周期钩子都会在其对应的阶段被调用,并在控制台输出一条消息。

五、总结

了解 Vue 3 的生命周期和生命周期函数是掌握 Vue 3 的关键一步。通过使用这些钩子函数,我们可以在组件的不同阶段执行特定的逻辑,从而更好地控制和管理组件的行为。

更多详细信息和更新内容,请参阅 Vue.js 官方文档

相关推荐
Dontla19 分钟前
为什么React列表项需要key?(React key)(稳定的唯一标识key有助于React虚拟DOM优化重绘大型列表)
javascript·react.js·ecmascript
EndingCoder1 小时前
React从基础入门到高级实战:React 实战项目 - 项目三:实时聊天应用
前端·react.js·架构·前端框架
阿阳微客2 小时前
Steam 搬砖项目深度拆解:从抵触到真香的转型之路
前端·笔记·学习·游戏
德育处主任Pro3 小时前
『React』Fragment的用法及简写形式
前端·javascript·react.js
CodeBlossom3 小时前
javaweb -html -CSS
前端·javascript·html
CodeCraft Studio3 小时前
【案例分享】如何借助JS UI组件库DHTMLX Suite构建高效物联网IIoT平台
javascript·物联网·ui
打小就很皮...4 小时前
HBuilder 发行Android(apk包)全流程指南
前端·javascript·微信小程序
集成显卡5 小时前
PlayWright | 初识微软出品的 WEB 应用自动化测试框架
前端·chrome·测试工具·microsoft·自动化·edge浏览器
前端小趴菜056 小时前
React - 组件通信
前端·react.js·前端框架
Amy_cx6 小时前
在表单输入框按回车页面刷新的问题
前端·elementui