Vue学习记录之五(组件/生命周期)

一、组件

在每一个.vue文件可以看作是一个组件,组件是可以复用的,每个应用可以看作是一棵嵌套的组件树。
在这里插入图片描述
在Vue3中,组件导入以后即可直接使用。
在这里插入图片描述

二、组件的生命周期

生命周期就是从诞生(创建)到死亡(销毁) 的过程。
Vue3 组合式API中(setup语法糖模式),是没有beforeCreate 和 created 这两个过程的。可以使用setup去代替。
在这里插入图片描述
运行流程

<template><div></div>
</template>
<script setup lang='ts'>
import { ref,onBeforeMount,onMounted,onBeforeUpdate,onUpdated,onBeforeUnmount,onUnmounted } from 'vue'
console.log("setup")
//创建
onBeforeMount(()=>{console.log("创建之前==========")
})
onMounted(()=>{console.log("创建完成==========")
})
//更新的钩子
onBeforeUpdate(()=>{console.log("更新组件之前==========")
})
onUpdated(()=>{console.log("更新组件完成==========")
})
// 销毁的钩子
onBeforeUnmount(()=>{console.log("销毁之前==========")
})
onUnmounted(()=>{console.log("销毁完成==========")
})</script>
<style scoped></style>

在这里插入图片描述

<template><div ref="getdiv">{{ name }}</div><button @click="change">修改name</button>
</template>
<script setup lang='ts'>
import { ref,onBeforeMount,onMounted,onBeforeUpdate,onUpdated,onBeforeUnmount,onUnmounted } from 'vue'
console.log("setup")
const name = ref("lvmanba")
const getdiv = ref<HTMLDivElement>()  //注意这里的变量名要和上面的ref属性的名称一致。
const change = () =>{name.value = "bird"
}
/*
1、在onMounted之前读取不到dom, onMounted可以读取到。
2、有内容更新的时候,才能触发onBeforeUpdate 和 onUpdated, 如上面点击修改内容的时候
3、onBeforeUpdate 是获取更新之前的dom,onUpdated才能获取更新之后的内容
*/
//创建
onBeforeMount(()=>{console.log("创建之前==========",getdiv.value)  //创建之前是undefined
})
onMounted(()=>{console.log("创建完成==========",getdiv.value) //这里可以获取到值
})
//更新的钩子
onBeforeUpdate(()=>{console.log("更新组件之前==========",getdiv.value?.innerHTML) //更新之前是lvmanba,也就是内容还没有被修改。
})
onUpdated(()=>{console.log("更新组件完成==========",getdiv.value?.innerHTML) // 更新之后是bird
})
// 销毁的钩子
onBeforeUnmount(()=>{console.log("销毁之前==========")
})
onUnmounted(()=>{console.log("销毁完成==========")
})</script>

使用销毁功能:
下面的是插件A.vue

<template><div ref="getdiv">{{ name }}</div><button @click="change">修改name</button>
</template>
<script setup lang='ts'>
import { ref,onBeforeMount,onMounted,onBeforeUpdate,onUpdated,onBeforeUnmount,onUnmounted,onRenderTracked,onRenderTriggered} from 'vue'
console.log("setup")
const name = ref("lvmanba")
const getdiv = ref<HTMLDivElement>()  //注意这里的变量名要和上面的ref属性的名称一致。
const change = () =>{name.value = "bird"
}
/*
1、在onMounted之前读取不到dom, onMounted可以读取到。
2、有内容更新的时候,才能触发onBeforeUpdate 和 onUpdated, 如上面点击修改内容的时候
3、onBeforeUpdate 是获取更新之前的dom,onUpdated才能获取更新之后的内容
*/
//创建
onBeforeMount(()=>{console.log("创建之前==========",getdiv.value)  //创建之前是undefined
})
onMounted(()=>{console.log("创建完成==========",getdiv.value) //这里可以获取到值
})
//更新的钩子
onBeforeUpdate(()=>{console.log("更新组件之前==========",getdiv.value?.innerHTML) //更新之前是lvmanba,也就是内容还没有被修改。
})
onUpdated(()=>{console.log("更新组件完成==========",getdiv.value?.innerHTML) // 更新之后是bird
})
// 销毁的钩子
onBeforeUnmount(()=>{console.log("销毁之前==========")
})
onUnmounted(()=>{console.log("销毁完成==========")
})
onRenderTracked((e)=>{console.log("onRenderTracked:",e)
})
onRenderTriggered((e)=>{console.log("onRenderTriggered:",e)
})</script>

入口文件App.vue
引入组件,并展示组件。

<template><div><!--当一个组件绑定了v-if,会触发组件的创建和销毁。v-show 无此功能。--><A v-if="flag"></A> <br><br><button @click="flag = !flag">{{ flag == true? "销毁":"创建"}}</button></div>
</template>
<script setup lang='ts'>
import { ref,reactive } from 'vue'
import A from './components/A.vue';
const flag = ref<boolean>(false)
</script>

在这里插入图片描述
下面是有一个完整的生命周期:
在这里插入图片描述
其次 还有 onRenderTracked,onRenderTriggered 两个钩子,主要是用来调试使用的。

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

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

相关文章

Rocky 8.7 操作系统 安装部署 MySQL 5.7.32 验证测试

一、安装部署 主从服务器都需提前安装部署MySQL 5.7.32 数据库软件&#xff0c;本次选择采用二进制安装。 配置主从&#xff0c;要注意调整主备库server_id不能保持一致。 主库修改/etc/my.cnf文件&#xff0c;添加 server-id1log-binmysql-binbinlog-do-dbmsdbbinlog-ign…

java se 快速入门

文章目录 java se 快速入门Java 简介Java的优点jdk 和 jre安装jdk配置环境变量Java 语法快速入门程序入口文件名类规范 基本语法注释变量和常量输入输出条件语句循环语句 基本数据类型Java字符串常用方法字符串拼接java字节数组和字符串相互转化java字符数组和字符串相互转换ja…

传输层协议 —— TCP协议(上篇)

目录 1.认识TCP 2.TCP协议段格式 3.可靠性保证的机制 确认应答机制 超时重传机制 连接管理机制 三次握手 四次挥手 1.认识TCP 在网络通信模型中&#xff0c;传输层有两个经典的协议&#xff0c;分别是UDP协议和TCP协议。其中TCP协议全称为传输控制协议&#xff08;Tra…

torch.embedding 报错 IndexError: index out of range in self

文章目录 1. 报错2. 原因3. 解决方法 1. 报错 torch.embedding 报错&#xff1a; IndexError: index out of range in self2. 原因 首先看下正常情况&#xff1a; import torch import torch.nn.functional as Finputs torch.tensor([[1, 2, 4, 5], [4, 3, 2, 9]]) embedd…

游戏如何检测加速外挂

在游戏面临的众多外挂风险中&#xff0c;除了常见的内存修改挂、注入挂等作弊手段&#xff0c;黑灰产还常用「加速」手段实现作弊。 游戏安全风险分布占比图 「加速」顾名思义是指改变游戏内的速度。游戏在运行中需要以帧为单位播放画面&#xff0c;而计算每帧动画播放所需时间…

代码随想录算法训练营第3天|链表理论基础、203. 移除链表元素、 707.设计链表、 206.反转链表

目录 链表理论基础203. 移除链表元素1、题目描述2、思路3、code4、复杂度分析 707. 设计链表1、题目描述2、思路3、code 206. 反转链表1、题目描述2、思路3、code4、复杂度分析 链表理论基础 ❤️链表增删的时间复杂度都是 O ( 1 ) O(1) O(1)&#xff0c;适合动态增删&#xf…

C语言进阶【4】---数据在内存中的存储【1】(你不想知道数据是怎样存储的吗?)

本章概述 整数在内存中的存储大小端字节序和字节序判断练习1练习2练习3练习4练习5练习6 彩蛋时刻&#xff01;&#xff01;&#xff01; 整数在内存中的存储 回忆知识&#xff1a;在讲操作符的那章节中&#xff0c;对于整数而言咱们讲过原码&#xff0c;反码和补码。整数分为有…

【初阶数据结构】一文讲清楚 “堆” 和 “堆排序” -- 树和二叉树(二)(内含TOP-K问题)

文章目录 前言1. 堆1.1 堆的概念1.2 堆的分类 2. 堆的实现2.1 堆的结构体设置2.2 堆的初始化2.3 堆的销毁2.4 添加数据到堆2.4.1 "向上调整"算法 2.5 从堆中删除数据2.5.1 “向下调整”算法 2.6 堆的其它各种方法接口函数 3. 堆排序3.1 堆排序的代码实现 4. TOP-K问题…

CWFED:自然灾害检测数据集(猫脸码客 第192期)

Cyclone Wildfire Flood Earthquake Database 在自然灾害频发的今天&#xff0c;准确、及时地获取并分析相关数据对于灾害预防、预警及响应至关重要。为此&#xff0c;Cyclone Wildfire Flood Earthquake Database&#xff08;以下简称CWFE Database&#xff09;应运而生&…

PostgreSQL 的log_hostname 参数测试

PostgreSQL 的log_hostname 参数测试 log_hostname 是 PostgreSQL 配置文件 (postgresql.conf) 中的一个参数&#xff0c;用于控制是否在日志条目中记录客户端主机名。默认情况下&#xff0c;PostgreSQL 只记录客户端的IP地址&#xff0c;而 log_hostname 参数允许数据库管理员…

使用FLBOOK快速制作3D电子版翻页产品册

​随着数字化时代的到来&#xff0c;传统纸质产品册已逐渐无法满足人们快节奏、便捷的生活方式。而FLBOOK&#xff0c;一款强大的3D电子版翻页产品册制作工具&#xff0c;凭借其简洁的操作界面、丰富的功能和出色的展示效果&#xff0c;已成为越来越多企业的首选。 1.要制作电子…

1:java的介绍与基础1:变量,数据类型与数学运算符

1.1Java的开始 从今天开始&#xff0c;我将更新一下关于学习Java的笔记&#xff0c;文章&#xff0c;希望大家支持。这个Java吧&#xff0c;感觉本质上逻辑始于python很类似&#xff0c;但是吧它的表达更加繁琐难懂&#xff0c;所以我还是喜欢python&#xff0c;比较简介明了。…

获取java jdk包的方式记录

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、OpenLogic方式二、华为源下载 前言 记录一下获取java jdk的方式方法。 一、OpenLogic方式 网址&#xff1a;https://www.openlogic.com/openjdk-download…

OCR两篇革命之作

DocOwl2 参考 阿里8B模型拿下多页文档理解新SOTA&#xff0c;324个视觉token表示一页&#xff0c;缩减80% mPLUG-DocOwl 2聚焦多页文档理解&#xff0c;兼顾效果和效率&#xff0c;在大幅缩减单页视觉token的前提下实现了多页文档理解的SOTA效果。 仅用324个token表示文档图…

相亲交易系统源码详解与开发指南

随着互联网技术的发展&#xff0c;越来越多的传统行业开始寻求线上转型&#xff0c;其中就包括婚恋服务。传统的相亲方式已经不能满足现代人快节奏的生活需求&#xff0c;因此&#xff0c;开发一款基于Web的相亲交易系统显得尤为重要开发者h17711347205。本文将详细介绍如何使用…

API接口在不同编程语言中是如何实现的?

API接口是现代软件开发中的关键技术&#xff0c;它允许不同的软件系统相互通信和交换数据。在不同的编程语言中&#xff0c;API接口的实现方式可能会有所不同&#xff0c;但它们的核心概念是一致的&#xff1a;提供一组预定义的方法和协议&#xff0c;使得开发者可以访问特定的…

SpringCloud~

帮你轻松入门SpringCloud~ 1 微服务概述 1.1什么是微服务 如idea中使用maven建立的一个个moudle&#xff0c;它具体是使用SpringBoot开发的一个小模块&#xff0c;专业的事交给专业的模块来做&#xff0c;每个模块完成一个具体的任务或功能。 1.2 什么是微服务架构 它将单一应用…

SAP B1 流程实操 - 营销单据销售部分(上)

背景 在 SAP B1 中&#xff0c;最重要的模块就是【销售】&#xff0c;企业可能不涉及生产和库存&#xff08;贸易公司&#xff09;&#xff0c;甚至不涉及采购&#xff08;服务业&#xff09;&#xff0c;但是一定会有基本的 销售。本文中我们讲解 销售 模块的基本核心&#x…

持续低迷的大环境下,写给技术人几句掏心窝的话

文章目录 一、写在前面二、职业发展&#xff1a;兴趣是关键点三、关于职业规划四、做事认真&#xff0c;提升效率五、不要怕事&#xff0c;多经历总是好的六、走技术还是走管理七、关于跳槽八、认识个人与团队的关系&#xff0c;并且学会自我管理九、做好知识归档、写好文档十、…

ORA-28032 Your password has expired and the database is set to read only

做个记录。 non-cdb 处于只读状态&#xff0c;CDB创建到noncdb的dblink后产生的报错&#xff0c;dblink可以成功创建&#xff0c;但无法连接到non-cdb。 解决&#xff1a;一开始以为是cdb的密码不正确&#xff0c;mos上找到问题&#xff0c;non-cdb的密码过期了&#xff0c;并且…