vue3 生命周期(生命周期钩子 vs 生命周期选项 vs 缓存实例的生命周期)

news2024/11/23 8:16:48

vue3 支持两种风格书写:选项式 API 和组合式 API

  • 若采用组合式 API ,则使用生命周期钩子
  • 若采用选项式 API ,则使用生命周期选项
  • 两者选用一种即可,不建议同时使用,避免逻辑紊乱。

在这里插入图片描述

生命周期钩子

在 setup 中使用

onBeforeMount()

组件被挂载之前执行回调

  • 组件已经完成了其响应式状态的设置,但还没有创建 DOM 节点。
  • 即将首次执行 DOM 渲染过程。
<script setup>
import { onBeforeMount } from 'vue'

onBeforeMount(() => {
  console.log("组件被挂载之前执行")
})
</script>

注意事项:
在服务器端渲染期间不会被调用

onMounted()

组件挂载完成后执行回调

  • 所有同步子组件都已经被挂载 (不包含异步组件或 树内的组件)。
  • 自身的 DOM 树已经创建完成并插入了父容器中
<script setup>
import { onMounted } from 'vue'

onMounted(() => {
  console.log("组件挂载完成后执行")
})
</script>

使用场景:

  • 执行需要访问组件所渲染的 DOM 树相关的副作用
  • 服务端渲染应用中用于确保 DOM 相关代码仅在客户端执行

注意事项:
在服务器端渲染期间不会被调用

onBeforeUpdate()

组件即将因为响应式状态变更而更新其 DOM 树之前执行回调

<script setup>
import { onBeforeUpdate } from 'vue'

onBeforeUpdate(() => {
  console.log("更新 DOM 树之前执行")
})
</script>

使用场景:
在 Vue 更新 DOM 之前访问 DOM 状态

注意事项:
在服务器端渲染期间不会被调用

onUpdated()

在组件因为响应式状态变更而更新其 DOM 树之后执行回调

  • 子组件中的 onUpdated 回调比父组件中的 onUpdated 回调先执行
  • 多个状态变更会在同一个渲染周期中批量执行 (为了提升性能)。如果需要在某个特定的状态更改后访问更新后的 DOM,需使用 nextTick()
<script setup>
import { onUpdated } from 'vue'

onUpdated(() => {
  console.log("更新 DOM 树之后执行")
})
</script>

注意事项:

  • 在服务器端渲染期间不会被调用
  • 不要在 onUpdated 中更改组件的状态,这可能导致无限的更新循环!

onBeforeUnmount()

组件实例被卸载之前执行回调

  • 此时组件实例依然还保有全部的功能
  • 对应 vue2 中的生命周期 beforeDestroy
<script setup>
import { onBeforeUnmount } from 'vue'

onBeforeUnmount(() => {
  console.log("组件被卸载之前执行")
})
</script>

注意事项:

  • 在服务器端渲染期间不会被调用

onUnmounted()

组件实例被卸载之后执行回调

  • 此时所有子组件都已经被卸载
  • 所有相关的响应式作用 (渲染作用以及 setup() 时创建的计算属性和侦听器) 都已经停止。
  • 对应 vue2 中的生命周期 destroyed
<script setup>
import { onUnmounted } from 'vue'

onUnmounted(() => {
  console.log("组件被卸载之后执行")
  // 清除计时器 timer
  clearInterval(timer)
})
</script>

使用场景:
手动清理一些副作用,例如计时器、DOM 事件监听器或者与服务器的连接。

注意事项:

  • 在服务器端渲染期间不会被调用

onActivated()

若组件实例是 <KeepAlive> 缓存树的一部分,当组件被插入到 DOM 中时执行回调

  • onActivated 在组件挂载时也会调用
  • 缓存的组件实例的生命周期 mounted 被 onActivated 替代
<script setup>
import { onActivated } from 'vue'

onActivated(() => {
  // 调用时机为首次挂载
  // 以及每次从缓存中被重新插入时
})
</script>

使用场景:
被缓存的组件实例重新被激活时

注意事项:

  • 在服务器端渲染期间不会被调用

onDeactivated()

若组件实例是 <KeepAlive> 缓存树的一部分,当组件从 DOM 中被移除时执行回调

  • onDeactivated 在组件卸载时也会调用
  • 缓存的组件实例的生命周期 unmounted 被 onDeactivated 替代
<script setup>
import { onDeactivated } from 'vue'

onDeactivated(() => {
  // 在从 DOM 上移除、进入缓存
  // 以及组件卸载时调用
})
</script>

使用场景:
被缓存的组件实例变为不活跃状态时

注意事项:

  • 在服务器端渲染期间不会被调用

其他生命周期不常用,可参考官网 了解即可。

生命周期选项

setup() 会在所有生命周期选项之前调用

beforeCreate

组件实例初始化完成之后执行回调

  • 此时 props 已被解析
  • 接着 props 会被定义成响应式属性,data() 和 computed 等选项也开始进行处理。
export default {
  beforeCreate() {
    console.log("组件初始化完成之后执行")
  }
}

created

组件实例处理完所有与状态相关的选项之后执行回调

  • 此时响应式数据、计算属性、方法和侦听器已经设置完成
  • 挂载阶段还未开始,因此 $el 属性仍不可用
export default {
  created() {
    console.log("组件处理完所有与状态相关的选项之后执行")
  }
}

beforeMount

组件被挂载之前执行回调

  • 此时已经完成了其响应式状态的设置,但还没有创建 DOM 节点
  • 即将首次执行 DOM 渲染过程
export default {
  beforeMount() {
    console.log("组件被挂载之前执行")
  }
}

注意事项:

  • 在服务器端渲染时不会被调用

mounted

组件被挂载之后执行回调

  • 所有同步子组件都已经被挂载。(不包含异步组件或 树内的组件)
  • 自身的 DOM 树已经创建完成并插入了父容器中。
export default {
  mounted() {
    console.log("组件被挂载之后执行")
  }
}

使用场景:

  • 执行需要访问组件所渲染的 DOM 树相关的副作用
  • 服务端渲染应用中用于确保 DOM 相关代码仅在客户端执行

注意事项:

  • 在服务器端渲染时不会被调用

beforeUpdate

组件即将因为一个响应式状态变更而更新其 DOM 树之前执行回调

export default {
  beforeUpdate() {
    console.log("组件更新前执行")
  }
}

使用场景:

  • 在 Vue 更新 DOM 之前访问 DOM 状态

注意事项:

  • 在服务器端渲染时不会被调用

updated

组件因为一个响应式状态变更而更新其 DOM 树之后执行回调

  • 子组件中的 updated 回调比父组件中的 updated 回调先执行
  • 不同的状态变更都会触发组件更新,如果需要在某个特定的状态更改后访问更新后的 DOM,需使用 nextTick()
export default {
  updated() {
    console.log("组件更新后执行")
  }
}

使用场景:

  • 在 Vue 更新 DOM 之前访问 DOM 状态

注意事项:

  • 在服务器端渲染时不会被调用
  • 不要在 updated 中更改组件的状态,这可能导致无限的更新循环!

beforeUnmount

组件实例被卸载之前执行回调

  • 此时组件实例依然还保有全部的功能
  • vue2 中的生命周期 beforeDestroy 改名而来
export default {
  beforeUnmount() {
    console.log("组件卸载之前执行")
  }
}

注意事项:

  • 在服务器端渲染时不会被调用

unmounted

组件实例被卸载之后执行回调

  • vue2 中的生命周期 destroyed 改名而来
  • 此时所有子组件都已经被卸载
  • 所有相关的响应式作用 (渲染作用以及 setup() 时创建的计算属性和侦听器) 都已经停止。
export default {
  unmounted() {
    console.log("组件卸载之后执行")
  }
}

使用场景:
手动清理一些副作用,例如计时器、DOM 事件监听器或者与服务器的连接。

注意事项:

  • 在服务器端渲染时不会被调用

activated()

若组件实例是 <KeepAlive> 缓存树的一部分,当组件被插入到 DOM 中时执行回调

  • activated 在组件挂载时也会调用
  • 缓存的组件实例的生命周期 mounted 被 activated替代
export default {
  activated() {
    // 在首次挂载、
    // 以及每次从缓存中被重新插入的时候调用
  }
}

使用场景:
被缓存的组件实例重新被激活时

注意事项:

  • 在服务器端渲染期间不会被调用

deactivated()

若组件实例是 <KeepAlive> 缓存树的一部分,当组件从 DOM 中被移除时执行回调

  • deactivated 在组件卸载时也会调用
  • 缓存的组件实例的生命周期 unmounted 被 deactivated 替代
export default {
  deactivated() {
    // 在从 DOM 上移除、进入缓存
    // 以及组件卸载时调用
  }
}

使用场景:
被缓存的组件实例变为不活跃状态时

注意事项:

  • 在服务器端渲染期间不会被调用

其他生命周期不常用,可参考官网 了解即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1601109.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于STC12C5A60S2系列1T 8051单片机的带字库液晶显示器LCD12864数据传输并行模式显示64行点x64列点字模的功能

基于STC12C5A60S2系列1T 8051单片机的带字库液晶显示器LCD12864数据传输并行模式显示64行点x64列点字模的应用 STC12C5A60S2系列1T 8051单片机管脚图STC12C5A60S2系列1T 8051单片机I/O口各种不同工作模式及配置STC12C5A60S2系列1T 8051单片机I/O口各种不同工作模式介绍液晶显示…

【Altium Designer 20 笔记】PCB层

Top Overlay & Bottom Overlay (顶部丝印层和底部丝印层)&#xff1a; 用于标记元件、连接和其他重要信息。丝印层是 PCB 表面的一层&#xff0c;上面印上文字、图标或标记。 Top Solder & Bottom Solder (顶部阻焊层和底部阻焊层)&#xff1a; 阻焊层、开窗层、绿油层…

内网穿透工具及技术总结

攻击主机在内网&#xff0c;控制其他网段内网的主机&#xff0c;理论上是不可行的&#xff08;攻击机和目标机都在内网 连接就是从内网到内网&#xff09; 绕过内网协议实现上线(穿透)&#xff0c;按照我的理解就是穿透技术解决的问题就是解决内网到内网、外网到内网的通信问题…

Visual Studio2010源码编译curl_7_60

一、源码解压目录内容 很开心里面可以找到CMakeLists.txt文件&#xff0c;说明可以实用CMake工具进行构建&#xff0c;由于多数开源项目都选择实用CMake作为构建编译工具&#xff0c;大家蝇该都比较熟练了。 二、实用CMake开始构建Visual Studio 2010工程 很顺利整个构建过程没…

06节-51单片机-LCD1602调试工具

欢迎订阅专栏&#xff0c;持续为您更新&#xff01; 1.LCD1602调试工具 使用LCD1602液晶屏作为调试窗口&#xff0c;提供类似printf函数的功能&#xff0c;可实时观察单片机内部数据的变换情况&#xff0c;便于调试和演示。 本文提供的LCD1602代码属于模块化的代码&#xff…

中国人工智能产业年会智能交通与自动驾驶专题全景扫描

中国人工智能产业年会&#xff08;CAIIAC&#xff09;是中国人工智能技术发展和应用的重要展示平台&#xff0c;不仅关注创新&#xff0c;还涵盖了市场和监管方面的内容&#xff0c;对于促进人工智能领域的发展起到了重要作用。年会汇集了来自学术界、工业界和政府的专家&#…

Github 2024-04-17 开源项目日报 Top10

根据Github Trendings的统计,今日(2024-04-17统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目2非开发语言项目2Vue项目1HTML项目1Rust项目1C项目1C++项目1Mojo项目1Jupyter Notebook项目1TypeScript项目1编程面试大学:成为软件…

QT系列教程(4) Qt 信号和槽

信号和槽 当我们需要一个界面通知另一个界面时&#xff0c;可以采用信号和槽机制。通过链接信号和槽&#xff0c;当一个界面发送信号时&#xff0c;链接该信号的槽会被响应&#xff0c;从而达到消息传递的目的。 所以我们先创建一个Qapplication Widgets 应用。Creator会为我们…

Pytorch入门实战 P06-调用vgg16模型,进行人脸预测

目录 1、本文内容&#xff1a; 1、内容&#xff1a; 2、简单介绍下VGG16&#xff1a; 3、相关其他模型也可以调用&#xff1a; 2、代码展示&#xff1a; 3、训练结果&#xff1a; 1、不同优化器&#xff1a; ①【使用SGD优化器】 ②【使用Adam优化器】 ③Adam 动态学…

Python数据可视化:无向网络图

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 Python数据可视化&#xff1a; 无向网络图 [太阳]选择题 关于以下代码输出结果的说法中正确的是? import networkx as nx import matplotlib.pyplot as plt a [(A, B), (B, C), (B, D)] …

zabbix 自动发现与自动注册 部署 zabbix 代理服务器

zabbix 自动发现&#xff08;对于 agent2 是被动模式&#xff09; zabbix server 主动的去发现所有的客户端&#xff0c;然后将客户端的信息登记在服务端上。 缺点是如果定义的网段中的主机数量多&#xff0c;zabbix server 登记耗时较久&#xff0c;且压力会较大。1.确保客户端…

淘宝API商品详情数据在数据分析行业中具有不可忽视的重要性

淘宝商品详情数据在数据分析行业中具有不可忽视的重要性。这些数据为商家、市场分析师以及数据科学家提供了丰富的信息&#xff0c;有助于他们更深入地理解市场动态、消费者行为以及商品竞争态势。以下是淘宝商品详情数据在数据分析行业中的重要性体现&#xff1a; 请求示例&a…

Customizable Ghosts Pack

“可定制的幽灵包”为游戏开发商快速将幽灵角色融入游戏提供了坚实的基础。鬼角色的标准解决方案。 Customizable Ghost Pack: “可自定义的幽灵包”为游戏开发商快速将幽灵怪物集成到游戏中提供了坚实的基础。鬼角色的标准解决方案。 关键功能 ⭐怪物创造者工具。 ⭐完全…

浅谈Spring的Bean生命周期

在Spring框架中&#xff0c;Bean&#xff08;即Java对象&#xff09;的生命周期涵盖了从创建到销毁的全过程&#xff0c;主要包含以下几个阶段&#xff1a; 实例化&#xff08;Instantiation&#xff09;&#xff1a; 当Spring IoC容器需要创建一个Bean时&#xff0c;首先会通过…

HCIA--综合实验(超详细)

要求&#xff1a; 1. 使用172.16.0.0/16划分网络 2.使用ospf协议合理规划区域保证更新安全 3.加快收敛速度 4. r1为DR没有BDR 5.PC2&#xff0c;3&#xff0c;4&#xff0c;5自动获取IP地址&#xff1b;PC1为外网&#xff0c;PC要求可用互相访问 6.r7为运营商&#xff0c;只能配…

[沫忘录]MySQL索引

[沫忘录]MySQL索引 索引概述 优点 提高数据检索效率&#xff0c;降低数据库IO成本通过索引对数据进行排序&#xff0c;降低数据排序成本&#xff0c;降低CPU消耗 缺点 索引会占用一定空间当更新数据时&#xff0c;也需更新索引数据&#xff0c;这会降低数据的更新效率 索引…

Adobe AE(After Effects)2023下载地址及安装教程

Adobe After Effects是一款专业级别的视觉效果和动态图形处理软件&#xff0c;由Adobe Systems开发。它被广泛用于电影、电视节目、广告和其他多媒体项目的制作。 After Effects提供了强大的合成和特效功能&#xff0c;可以让用户创建出令人惊艳的动态图形和视觉效果。用户可以…

LabVIEW变速箱自动测试系统

LabVIEW变速箱自动测试系统 在农业生产中&#xff0c;采棉机作为重要的农用机械&#xff0c;其高效稳定的运行对提高采棉效率具有重要意义。然而&#xff0c;传统的采棉机变速箱测试方法存在测试效率低、成本高、对设备可能产生损害等问题。为了解决这些问题&#xff0c;开发了…

[docker] 镜像部分补充

[docker] 镜像部分补充 这里补充一下比较少用的&#xff0c;关于镜像的内容 检查镜像 ❯ docker images REPOSITORY TAG IMAGE ID CREATED SIZE <none> <none> ca61c1748170 2 hours ago 1.11GB node latest 5212d…

数据中心IP代理VS住宅代理IP,区别详解

一、什么是数据中心/机房IP代理&#xff1f; 数据中心/机房IP代理是使用数据中心拥有并进行分配和管理的IP的代理&#xff0c;俗称机房IP代理。 二、数据中心/机房IP代理的特点 与住宅代理通过使用ISP拥有和分配的IP地址的设备路由请求的情况不同&#xff0c;数据中心代理利…