Vue3 Lifecycle Hooks

Vue 3 生命周期钩子详解

Vue 3 的生命周期钩子分为 Options APIComposition API 两种使用方式,核心流程相同但语法有差异。以下是完整生命周期流程和每个钩子的详细说明:


Composition API 生命周期流程图

html 复制代码
<template>
  <div>实际参数{{count}}</div>
</template>

<script setup lang="ts">
import {
  ref,
  onBeforeMount,
  onMounted,
  onBeforeUpdate,
  onUpdated,
  onBeforeUnmount,
  onUnmounted,
} from "vue";

const count= ref<number>(0)
let timer = ref<any>(null)
// 挂载阶段
onBeforeMount(() => {
  console.log('DOM挂载前')
})

onMounted(() => {
  console.log('DOM已挂载')
  timer.value = setInterval(()=> {
    count.value += 1
  },1000)
})

// 数据已经更新
onBeforeUpdate(() => {
  console.log('数据更新前',  count.value)
})

onUpdated(() => {
  console.log('数据更新后')
})

// 卸载阶段
onBeforeUnmount(() => {
  console.log('组件卸载前')
})

onUnmounted(() => {
  console.log('组件已卸载')
})

</script>
1. 创建阶段 (Creation)
Options API Composition API 触发时机
beforeCreate setup() 替代 组件实例初始化前,无法访问 datamethods
created setup() 替代 组件实例创建完成,可访问 data/methods,但未挂载 DOM
2. 挂载阶段 (Mounting)
Options API Composition API 触发时机
beforeMount onBeforeMount DOM 挂载前,虚拟 DOM 已生成,但未插入页面
mounted onMounted DOM 挂载完成,可操作真实 DOM,子组件不一定完成挂载
3. 更新阶段 (Updating)
Options API Composition API 触发时机
beforeUpdate onBeforeUpdate 数据变化后,虚拟 DOM 重新渲染前(适合获取更新前状态)
updated onUpdated 虚拟 DOM 重新渲染完成,DOM 已更新(避免在此修改状态,可能循环更新)
4. 卸载阶段 (Unmounting)
Options API Composition API 触发时机
beforeUnmount onBeforeUnmount 组件卸载前,实例仍可用(清理定时器/事件监听)
unmounted onUnmounted 组件卸载完成,所有绑定和监听被移除
5. 特殊钩子
钩子 用途
onErrorCaptured 捕获子孙组件的错误(类似 React ErrorBoundary)
onRenderTracked 开发调试:跟踪虚拟 DOM 重新渲染时的依赖
onRenderTriggered 开发调试:追踪触发重新渲染的依赖变化
onActivated <keep-alive> 缓存的组件激活时调用
onDeactivated <keep-alive> 缓存的组件停用时调用
javascript 复制代码
// 错误捕获示例
import { onErrorCaptured } from 'vue';

export default {
  setup() {
    onErrorCaptured((err, instance, info) => {
      console.error("子组件错误:", err);
      return false; // 阻止错误向上传播
    });
  }
}

最佳实践

  1. 资源清理 :在 onBeforeUnmount/onUnmounted 中移除事件监听、定时器。
  2. 避免在 onUpdated 修改状态:可能导致无限循环更新。
  3. 异步操作 :在 onMountedsetup 中发起 API 请求。
  4. DOM 操作 :必须在 onMounted 之后进行。
  5. Composition API 优势:逻辑更聚合,同一功能代码集中管理。
javascript 复制代码
// Composition API 逻辑聚合示例
export default {
  setup() {
    // 数据逻辑
    const data = ref(null);
    
    // 生命周期整合
    onMounted(fetchData);
    onUnmounted(cleanup);
    
    // 方法集中定义
    function fetchData() {
      axios.get('/api').then(res => data.value = res);
    }
    
    function cleanup() { /* ... */ }
    
    return { data };
  }
}

💡 提示:Vue 3 中 beforeDestroydestroyed 已重命名为 onBeforeUnmount/onUnmounted,更语义化。

相关推荐
CodeSheep13 分钟前
Stack Overflow,轰然倒下了!
前端·后端·程序员
i紸定i13 分钟前
解决html-to-image在 ios 上dom里面的图片不显示出来
前端·ios·vue·html·html-to-image
ai.Neo15 分钟前
(第十七期)HTML图像标签详解:从入门到精通
前端·html
阿珊和她的猫16 分钟前
autofit.js: 自动调整HTML元素大小的JavaScript库
开发语言·javascript·html
excel19 分钟前
JS 函数终极指南:this、闭包、递归、尾调用、柯里化,一次性吃透
前端
夏天想20 分钟前
html模拟websocket通信
前端
Stringzhua43 分钟前
Vue中的数据渲染【4】
css·vue.js·css3
阿珊和她的猫5 小时前
v-scale-scree: 根据屏幕尺寸缩放内容
开发语言·前端·javascript
加班是不可能的,除非双倍日工资9 小时前
css预编译器实现星空背景图
前端·css·vue3
wyiyiyi10 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask