【Vue3】组件生命周期

news2024/11/28 19:44:25

【Vue3】组件生命周期

  • 背景
  • 简介
  • 开发环境
  • 开发步骤及源码

背景

随着年龄的增长,很多曾经烂熟于心的技术原理已被岁月摩擦得愈发模糊起来,技术出身的人总是很难放下一些执念,遂将这些知识整理成文,以纪念曾经努力学习奋斗的日子。本文内容并非完全原创,大多是参考其他文章资料整理所得,感谢每位技术人的开源精神。

简介

本文介绍 Vue 组件生命周期。

Vue 组件生命周期包含四个阶段:

  • 创建
  • 挂载
  • 更新
  • 销毁

生命周期各阶段对应以下 Hooks 函数:

阶段Vue3 Hooks 函数Vue2 Hooks 函数
创建 - 创建前setupbeforeCreate
创建 - 创建完毕setupcreated
挂载 - 挂载前onBeforeMountbeforeMount
挂载 - 挂载完毕onMountedmounted
更新 - 更新前onBeforeUpdatebeforeUpdate
更新 - 更新完毕onUpdatedupdated
销毁 - 销毁前onBeforeUnmountedbeforeDestroy
销毁 - 销毁完毕onUnmounteddestroyed

Vue3 与 Vue2 生命周期 Hooks 函数的区别:

  • Vue3 创建阶段对应 setup
  • Vue3 Hooks 函数名添加了 on 前缀;
  • Vue3 挂载(Mount)和销毁(Unmount)对应的 Hooks 函数名相互对应。

本文主要演示 Vue3 生命周期 Hooks 函数代码。

开发环境

分类名称版本
操作系统WindowsWindows 11
IDEVisual Studio Code1.91.1

开发步骤及源码

1> 创建 Vue3 工程,参考:【Vue3】工程创建及目录说明。

2> 删除 src 目录下 assetscomponents 目录。

3> 修改 src 目录下 main.ts

import { createApp } from 'vue'
import App from './App.vue'

createApp(App).mount('#app')

4> 自定义功能组件 src/components/Demo.vue,在生命周期各阶段对应的 Hooks 函数中执行打印。

<template>
    <div class="demo" 
        @click="changeColor" 
        :style="{ backgroundColor: color }"
    >
        <h1>{{ title }}</h1>
    </div>
</template>

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

const title = ref('自定义功能组件')
const color = ref('orange')

function changeColor() {
    color.value = (color.value == 'orange') ? 'yellow' : 'orange'
}

console.log('创建:', title.value)

onBeforeMount(() => {
    console.log('挂载前:', title.value)
})

onMounted(() => {
    console.log('挂载完毕:', title.value)
})

onBeforeUpdate(() => {
    console.log('更新前:', title.value)
})

onUpdated(() => {
    console.log('更新完毕:', title.value)
})

onBeforeUnmount(() => {
    console.log('销毁(卸载)前:', title.value)
})

onUnmounted(() => {
    console.log('销毁(卸载)完毕:', title.value)
})
</script>

5> 修改 Vue 根组件 src/App.vue,引用自定义功能组件,并在生命周期各阶段对应的 Hooks 函数中执行打印。

<template>
  <div class="root"
    @click="changeColor"
    :style="{ backgroundColor: color }"
  >
    <h1>{{ title }}</h1>
    <button @click="presence = !presence">隐藏/显示自定义功能组件</button>
    <Demo v-if="presence" />
  </div>
</template>

<script setup lang="ts">
import Demo from './components/Demo.vue'
import { onBeforeMount, onBeforeUnmount, onBeforeUpdate, onMounted, onUnmounted, onUpdated, ref } from 'vue'

const title = ref('App组件')
const color = ref('blue')
const presence = ref(true)

function changeColor() {
  color.value = (color.value == 'blue') ? 'green' : 'blue'
}

console.log('创建:', title.value)

onBeforeMount(() => {
    console.log('挂载前:', title.value)
})

onMounted(() => {
    console.log('挂载完毕:', title.value)
})

onBeforeUpdate(() => {
    console.log('更新前:', title.value)
})

onUpdated(() => {
    console.log('更新完毕:', title.value)
})

onBeforeUnmount(() => {
    console.log('销毁(卸载)前:', title.value)
})

onUnmounted(() => {
    console.log('销毁(卸载)完毕:', title.value)
})
</script>

<style scoped lang="scss">
.root {
  padding: 20px;
}
</style>

注意:需要执行 npm install -D sass 命令安装 CSS 预处理器。

6> 执行命令 npm run dev,浏览器访问 http://localhost:5173/,观察浏览器控制台中的日志打印。
启动日志
从日志中可以看出,先执行根组件 创建挂载前,在 根组件挂载过程中 执行子组件的 创建挂载,当子组件 挂载完毕 后才触发根组件 挂载完毕

7> 点击根组件 <div> 区域,注意不要点击到子组件的 <div> 区域,观察日志打印。
根组件更新日志
可见只触发了根组件 更新

8> 点击子组件的 <div> 区域,观察日志打印。
子组件更新日志
先触发子组件 更新,然后触发根组件 更新,因为默认 JS 事件冒泡。

9> 点击页面中 隐藏/显示自定义功能组件 按钮隐藏组件,观察日志打印。
隐藏组件日志
首先触发根组件 更新前,在 根组件更新过程中 触发子组件 销毁(卸载),然后触发根组件 更新完毕

10> 点击页面中 隐藏/显示自定义功能组件 按钮显示组件,观察日志打印。
显示组件日志
首先触发根组件 更新前,在 根组件更新过程中 触发子组件 创建挂载,子组件 挂载完毕 后触发根组件 更新完毕

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

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

相关文章

Java从入门初级开发到精通百万级架构师:全套教程 | 学习路线(免费白嫖)

以下是一篇关于Java编程从入门到精通的文章&#xff0c;旨在帮助初学者和有一定基础的程序员系统地学习Java语言及其应用&#xff1a; Java语言编程从入门到精通&#xff1a;Java从入门到项目实战全套教程 Java作为一种广泛使用的编程语言&#xff0c;拥有强大的生态系统和丰富…

「 LaTeX 」如何修改公式底纹颜色

一、前言 小白在论文返修过程中&#xff0c;需要标注出部分公式的修正&#xff0c;因此用到这个代码指令。 二、技术实现 指令代码如下&#xff1a; \mathcolorbox{yellow}{ TEXT } 三、实例 \begin{figure*} \begin{equation} \centering \begin{aligned}\begin{bmatrix}{…

食家巷胡麻饼酥脆滋味,难以抗拒

在美食的浩瀚星空中&#xff0c;食家巷胡麻饼宛如一颗璀璨的明珠&#xff0c;散发着独特而迷人的魅力。食家巷胡麻饼&#xff0c;那金黄酥脆的外皮&#xff0c;宛如一层精心雕琢的铠甲&#xff0c;闪烁着诱人的光泽。上面点缀着密密麻麻的胡麻籽&#xff0c;犹如繁星点点&#…

终端pip安装包后,Pycharm却导入失败?新手别慌,3招搞定!

很多小伙伴在学习Python的过程中,都会遇到这种情况:明明在终端用pip安装好了需要的包,但在Pycharm中导入时却报错。难道是安装姿势不对? 例如在cmd中已经有了pandas,但是去pycharm中导入pandas显示没有 先别急着怀疑人生,这很可能是因为pip安装包的路径和Pycharm项目使用…

Docker容器下面home assistant忘记账号密码怎么重置?

环境&#xff1a; docker ha 问题描述&#xff1a; Docker容器下面home assistant忘记账号密码怎么重置&#xff1f; 解决方案&#xff1a; 你可以按照以下步骤来找回或重置密码&#xff1a; 方法一 (未解决) 停止并删除当前的Home Assistant容器&#xff08;确保你已经保…

设计模式16-代理模式

设计模式16-代理模式 动机定义与结构模式定义结构 代码推导特点应用总结实例说明1. 远程代理2. 虚拟代理3. 保护代理4. 智能引用代理 动机 在面向对象系统中有一些对象由于某种原因比如对象创建的开销很大或者某些操作需要安全控制&#xff0c;或者需要进程外的访问等情况。直…

Mac电脑流氓软件怎么卸载不了 MacBook删除恶意软件 电脑流氓软件怎么彻底清除

对于Mac用户来说&#xff0c;尽管MacOS系统以其较高的安全性而闻名&#xff0c;但依然不可避免地会遭遇流氓软件或恶意软件的困扰。本文将详细介绍Mac电脑流氓软件怎么卸载&#xff0c;Mac电脑如何移除移除恶意软件&#xff0c;确保你的设备运行安全、流畅。 一、Mac电脑流氓软…

【论文共读】【翻译】【GAN】Generative Adversarial Nets

论文原文地址&#xff1a;https://arxiv.org/pdf/1406.2661 翻译&#xff1a;Generative Adversarial Nets 生成对抗网络 0. 摘要 提出了一种新的对抗过程估计生成模型的框架&#xff0c;其中我们同时训练两个模型&#xff1a;一个是捕获数据分布的生成模型G&#xff0c;另一…

【基础夯实】TCP/IP 协议是怎么控制数据收发

【基础夯实】TCP/IP 协议是怎么控制数据收发 网址输入到页面完整显示&#xff0c;对于此问题&#xff0c;粗略的解释可以分为以下几个步骤&#xff1a; 客户端通过 HTTP 协议对数据进行一次包装通过 DNS 服务器&#xff08;本地无缓存&#xff09;解析网址的 ip 地址通过 TCP…

layui 乱入前端

功能包含 本实例代码为部分傻瓜框架&#xff0c;插入引用layui。因为样式必须保证跟系统一致&#xff0c;所以大部分功能都是自定义的。代码仅供需要用layui框架&#xff0c;但原项目又不是layui搭建的提供解题思路。代码较为通用 自定义分页功能自定义筛选列功能行内编辑下拉、…

【React】详解如何获取 DOM 元素

文章目录 一、基础概念1. 什么是DOM&#xff1f;2. 为什么需要获取DOM&#xff1f; 二、使用 ref 获取DOM元素1. 基本概念2. 类组件中的 ref3. 函数组件中的 ref 三、 ref 的进阶用法1. 动态设置 ref2. ref 与函数组件的结合 四、处理特殊情况1. 多个 ref 的处理2. ref 与条件渲…

跟着丑萌气质狗学习WPF——Style样式

Style样式 1. 用法介绍2. 样式多样性3. 全局样式说明和资源字典的使用 1. 用法介绍 提前写好样式&#xff0c;让他作用于所有按钮 <Window x:Class"WPF_Study_Solution.window3"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmln…

typescript 解构时配置类型

以下三种写法&#xff0c;可以参考&#xff1a; const handleMenuClick ({item, key, keyPath}: {item: Object, key: string, keyPath:string}) > {} const handleMenuClick ({item, key, keyPath}: any) > {} interface SomeObj {item: Objectkey: stringkeyPath:st…

计算机系统操作系统简介

目录 1.计算机系统简介 1.1组成结构 1.2系统软件 1.3冯诺依曼计算机特点 1.4硬件构架 2.硬件的进一步认识 2.1存储器 2.2输入设备 2.3输出设备 2.4CPU组成 2.5线的概念引入 3.操作系统 3.1操作系统简介 3.2操作系统如何管理 3.3库函数和系统调用 1.计算机系统简介…

Linux 用户管理模式

目录 1. 概述 2. 管控级别 3. 用户组管理 4. 用户管理 4.1 创建用户 useradd 4.2 删除用户 userdel ​编辑4.3 查看用户所属组 id 4.4 修改用户所属组 usermod 5. 查看用户/用户组 5.1 查看系统用户 5.2 查看系统用户组 1. 概述 Linux 可以配置多个用户&#xff0c…

ppt中国风背景图片去哪找?附6个优质中国风PPT模板分享!

在这个全球化的时代&#xff0c;中国传统文化元素正在各个领域焕发出新的生机&#xff0c;不管是在时尚、建筑还是平面设计领域&#xff0c;中国风都以其独特的美学魅力吸引着世界的目光。在商业演示和学术报告中&#xff0c;PowerPoint(PPT)作为最常用的工具之一&#xff0c;同…

opencv arm 交叉编译

step1.opencv源码文件夹下新建build-arm目录 step2. cmake图像化配置 cmake-gui .. step3. 选择交叉编译 step4.检索交叉编译链路径 step5. 配置 配置install路径 配置编译、链接选项 添加人脸检测模块 config->generate step6. make编译 built-arm目录下&#xff1a; …

DC-DC转换器电感参数详解

我们对DC-DC转换器的要求以及电感参数中的电感值、公差和电阻进行了介绍。本文中&#xff0c;我们将对电感的其它参数进行详细讲解。 自谐频率&#xff08;SRF&#xff09; 每个电感线圈都有一些联带的分布电容&#xff0c;与电感值一起形成一个有自谐频率的并联谐振回路。对…

探索局域网传输新境界 | 闪电藤 v2.2.7

在这个数字化时代&#xff0c;文件的快速、安全传输是我们日常工作中不可或缺的一部分。今天&#xff0c;电脑天空向大家介绍一款革命性的局域网文件传输工具——闪电藤&#xff0c;它将彻底改变你的文件传输体验。 &#x1f3a8; 界面设计 —— 极简之美 闪电藤采用极简的设…

【自动化测试必学语言】python:语言基础

目录 Python 介绍 语言的分类 注释 单行注释 多行注释 变量 定义变量 使用变量 变量名的命名规范 数据类型 数字类型 非数字类型 type() 函数 input输入 print输出 格式化输出 快捷键(小操作) 运算符 算术运算符 比较运算符 Python 介绍 作者&#xff1a; 吉…