【Vue】探究 Vue 2 与 Vue 3 生命周期:变化与延续

news2024/11/24 12:12:10

💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢迎在文章下方留下你的评论和反馈。我期待着与你分享知识、互相学习和建立一个积极的社区。谢谢你的光临,让我们一起踏上这个知识之旅!
请添加图片描述

文章目录

  • 🍀什么是生命周期?
  • 🍀Vue2的生命周期
  • 🍀Vue3的生命周期
  • 🍀 Vue 2 与 Vue 3 生命周期的变化
  • 🍀 结论

🍀什么是生命周期?

生命周期指的是事物从诞生到消亡所经历的各个阶段或过程。在软件开发中,特别是在前端开发中,生命周期通常指的是一个软件组件(比如网页、应用程序)从创建到销毁的整个过程。在这个过程中,组件会经历不同的阶段,每个阶段都有自己的特点和功能

如果问它有啥用的话,那么就是它可以帮助开发者更好地理解和控制软件的行为,例如在特定阶段执行特定的操作,或者释放资源以防止内存泄漏,本节我们将简单介绍一下Vue2,3当中的生命周期,以及它们的相同不同之处


🍀Vue2的生命周期

前几节我们都是使用Vue3进行实操,但是我们还没有创建过Vue2的项目,这里我们创建一个Vue2的项目
我们再来回顾一下

vue create vue2_test

接下来我们选择vue2
在这里插入图片描述

接下来我们就暂且等待创建成功吧
在这里插入图片描述

创建完成后,我们将根组件也就是App.vue中的内容进行清理一下,同时创建一个Person.vue作为子组件,同时在子组件里面写上我们的初识代码

<template>
 
</template>

<script>

export default {
  name: 'Person',
}
</script>

相比于Vue3,Vue2的运行命令如下

npm run serve

别忘了根组件的书写

<template>
 <Person/>
</template>

<script>
import Person from './components/Person.vue'
export default {
  name: 'App',
  components:{Person}
}
</script>


接下来我们上正题
在 Vue 2 中,组件的生命周期包括了创建、挂载、更新和销毁四个阶段。下面是 Vue 2 的生命周期钩子函数列表:

  • beforeCreate: 在实例初始化之后,数据观测 (data observer) 和事件配置 (event watchers) 之前被调用。
  • created: 实例已经创建完成后被调用,此时组件的数据绑定、计算属性、方法、事件等都已初始化。
beforeCreate(){
	console.log('创建前')
},
created(){
	console.log('创建完毕')
}
  • beforeMount: 在挂载开始之前被调用,相关的渲染函数首次被调用。
  • mounted: 实例挂载完成后被调用,此时 DOM 元素已经插入文档中。
beforeMount(){
	console.log('挂载前')
},
mounted(){
	console.log('挂载完毕')
}
  • beforeUpdate: 数据更新时调用,发生在虚拟 DOM 重新渲染和打补丁之前。
  • updated: 组件更新完成后被调用,此时 DOM 已经更新。
beforeUpdate(){
	console.log('更新前')
},
updated(){
	console.log('更新完毕')
}
  • beforeDestroy: 实例销毁之前调用。在这一步,实例仍然完全可用。
  • destroyed: 实例销毁后调用,此时 Vue 实例的所有指令、事件监听器被移除,所有子实例也被销毁。
beforeDestroy(){
	console.log('销毁前')
},
destroyed(){
	console.log('销毁完毕')
}

🍀Vue3的生命周期

在 Vue 3 中,与 Vue 2 类似,依然保留了创建、挂载、更新和销毁四个阶段,但在细节上有所调整和优化。Vue 3 为了提高性能,对一些生命周期钩子进行了拆分和合并。

下面是 Vue 3 的生命周期钩子函数列表:

  • setup:创建
  • onBeforeMount: 在挂载开始之前被调用,相关的渲染函数首次被调用。
  • onMounted: 实例挂载完成后被调用,此时 DOM 元素已经插入文档中。
  • onBeforeUpdate: 数据更新时调用,发生在虚拟 DOM 重新渲染和打补丁之前。
  • onUpdated: 组件更新完成后被调用,此时 DOM 已经更新。
  • onBeforeUnmount: 在卸载组件之前调用。
  • onUnmounted: 组件卸载后调用。
	// 创建
    console.log('创建')
  
    // 挂载前
    onBeforeMount(()=>{
      // console.log('挂载前')
    })
    // 挂载完毕
    onMounted(()=>{
      //console.log('挂载完毕')
    })
    // 更新前
    onBeforeUpdate(()=>{
      // console.log('更新前')
    })
    // 更新完毕
    onUpdated(()=>{
      // console.log('更新完毕')
    })
    // 卸载前
    onBeforeUnmount(()=>{
      // console.log('卸载前')
    })
    // 卸载完毕
    onUnmounted(()=>{
      // console.log('卸载完毕')
    })

注意:父组件的最后挂载的


🍀 Vue 2 与 Vue 3 生命周期的变化

在 Vue 3 中,生命周期钩子函数的名称发生了变化,从 before 和 mounted 变为 onBefore 和 onMounted。这样的调整使得生命周期钩子的命名更加一致和清晰。此外,Vue 3 还将销毁阶段的钩子函数从 beforeDestroy 和 destroyed 合并为 onBeforeUnmount 和 onUnmounted,简化了生命周期的管理和理解。

另外,Vue 3 通过引入 Composition API,进一步提升了组件的灵活性和复用性。通过 Composition API,开发者可以更加自由地组织组件逻辑,不再受限于固定的生命周期钩子函数,这对于复杂组件的开发尤为重要。

🍀 结论

本文对 Vue 2 和 Vue 3 的生命周期进行了对比与分析,介绍了两者的异同点。Vue 3 在保留 Vue 2 生命周期特性的基础上,做出了一些调整和优化,以提升开发体验和性能。了解和熟悉 Vue 的生命周期对于正确使用和优化 Vue 应用程序至关重要,希望本文能够帮助读者更好地理解和应用 Vue.js。

请添加图片描述

挑战与创造都是很痛苦的,但是很充实。

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

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

相关文章

MWC 2024 | 广和通携手意法半导体发布智慧家居解决方案

世界移动通信大会2024期间&#xff0c;广和通携手横跨多重应用领域、全球排名前列的半导体公司意法半导体&#xff08;STMicroelectronics&#xff0c;以下简称ST&#xff1b;纽约证券交易所代码&#xff1a;STM&#xff09;发布支持Matter协议的智慧家居解决方案。该方案在广和…

b站小土堆pytorch学习记录—— P15 Dataloader的使用

文章目录 一、前置知识1.dataloader简要介绍2.dataloader 官方文档&#xff08;翻译后&#xff09; 二、DataLoader的使用 一、前置知识 1.dataloader简要介绍 DataLoader 是 PyTorch 中用于加载数据的实用工具&#xff0c;它可以处理数据集的批量加载、数据集的随机打乱、多…

面试经典150题 -- 回溯 (总结)

总的链接 : 面试经典 150 题 - 学习计划 - 力扣&#xff08;LeetCode&#xff09;全球极客挚爱的技术成长平台 17 . 电话号码的字母组合 1 . 先创建一个下标 与 对应字符串映射的数组&#xff0c;这里使用hash表进行映射也是可以的 &#xff1b; 2 . 对于回溯 &#xff0c;…

【DUSt3R】2张图2秒钟3D重建

【DUSt3R】2张图2秒钟3D重建 1. DUSt3R是一种用于稠密和无约束立体三维重建的方法,其实现步骤如下:2. 实际运行效果3. 运行结果4. 自问自答4.1 为社么这里要是使用transform模型呢?4.2 CroCo(通过跨视图完成3D视觉任务的自我监督预训练的一个研究)在DUSt3R的作用是什么,为…

蓝桥杯集训·每日一题2024 (差分)

前言&#xff1a; 差分笔记以前就做了&#xff0c;在这我就不再写一遍了&#xff0c;直接上例题。 例题&#xff1a; #include<bits/stdc.h> using namespace std; int a[10009],b[100009]; int main(){int n,ans10,ans20;cin>>n;for(int i1;i<n;i){cin>>…

凸优化和非凸优化

在数学中一个非凸的最优化问题是什么意思&#xff1f; 1、凸优化和非凸优化的定义 2、凸优化&#xff1a;相对简单 在凸集中&#xff0c;有个基本理论&#xff0c;那就是任意局部最优解一定是全局最优解。基于这个性质&#xff0c;设计一个简单的局部算法&#xff0c;比如 贪…

MySQL 的备份方式

MySQL 的备份方式 1. 逻辑备份 逻辑备份是指将数据库中的数据导出为可读的 SQL 语句&#xff0c;通过这些语句可以还原数据库的结构和数据。 使用 mysqldump 工具进行逻辑备份 - **命令示例&#xff1a;**mysqldump -u [username] -p [database_name] > backup_file.sql- …

企微hook源码第二弹

免费的企微框架&#xff0c;可下载测试。 支持文本消息&#xff0c;图片消息&#xff0c;视频消息&#xff0c;文件消息。 有兴趣可以进群交流。649480745&#xff0c;群内不定期开源企微hook源码 接下来就是第二弹的企微hook源码。后续会在群内开源完整源码。

【比较mybatis、lazy、sqltoy、mybatis-flex、easy-query操作数据】操作批量新增、分页查询(三)

orm框架使用性能比较 比较mybatis、lazy、sqltoy、mybatis-flex、easy-query操作数据 环境&#xff1a; idea jdk17 spring boot 3.0.7 mysql 8.0测试条件常规对象 orm 框架是否支持xml是否支持 Lambda对比版本mybatis☑️☑️3.5.4sqltoy☑️☑️5.2.98lazy✖️☑️1.2.4…

CodeFlying 和 aixcoder两大免费软开平台,孰强孰弱?

今天为大家带来码上飞CodeFlying和aixcoder两款免费的软件开发平台效果的测评 一、产品介绍 首先简单介绍一下这两个平台 码上飞CodeFlying&#xff1a;码上飞 CodeFlying | AI 智能软件开发平台&#xff01; 是一款革命性的软件开发平台&#xff0c;它通过将软件工程和大模…

分库分表如何管理不同实例中几万张分片表?

在进行分库分表设计时&#xff0c;确认好了数据节点数量和分片策略以后&#xff0c;接下来要做的就是管理大量的分片表。实际实施过程中可能存在上百个分片数据库实例&#xff0c;每个实例中都可能有成千上万个分片表&#xff0c;如果仅依靠人力来完成这些任务显然是不现实的。…

spring自定义事件监听器

1. 创建自定义事件 import org.springframework.context.ApplicationEvent; import java.util.List;public class CollectionCreateEvent extends ApplicationEvent {private List<String> fileList;public CollectionCreateEvent(Object source,List<String> file…

【CSP试题回顾】201312-2-ISBN号码

CSP-201312-2-ISBN号码 解题思路 输入ISBN码&#xff1a;从用户接收一个ISBN字符串。 初始化变量&#xff1a;创建一个向量verifyArray来存储ISBN的前9位数字&#xff0c;和两个整数identificationCode和checkSum分别用于存储ISBN的校验位和计算出的校验和。 处理ISBN字符串…

道路积水监测站——确保道路畅通和行车安全

TH-JS1道路积水监测站是一种专门用于监测城市道路积水情况的设备&#xff0c;旨在保障城市道路安全和防止水患对交通造成的不利影响。这些监测站通过实时检测和记录道路积水数据&#xff0c;为城市管理部门提供重要信息&#xff0c;以便及时采取应对措施&#xff0c;确保道路畅…

【CSP试题回顾】201409-2-画图

CSP-201409-2-画图 解题思路 定义picture的二维数组&#xff0c;用于记录每个单元是否被涂色。数组的大小被设置为105x105&#xff0c;这是为了确保能够覆盖题目中可能出现的所有坐标。 输入变量n&#xff0c;表示将要绘制的矩形数量。 对于每个矩形&#xff0c;读取其左下角…

Ruoyi框架上传文件

axios资料&#xff1a;axios中文文档|axios中文网 | axios axiosjson 默认情况下&#xff0c;axios将JavaScript对象序列化为JSON。 submit(data) {if (data && this.definitionId) {// 启动流程并将表单数据加入流程变量startProcess(this.definitionId, JSON.string…

MySQL--优化(SQL语句执行慢,如何分析)

MySQL–优化&#xff08;SQL语句执行慢&#xff0c;如何分析&#xff09; 定位慢查询SQL执行计划索引 存储引擎索引底层数据结构聚簇和非聚簇索引索引创建原则索引失效场景 SQL优化经验 一、如何分析 聚合查询&#xff1a; 对于涉及大量数据的聚合操作&#xff0c;如果可能的…

【GIS技术】GIS在地质灾害易损性评价、危险性评估与灾后重建中的实践技术应用

地质灾害是指全球地壳自然地质演化过程中&#xff0c;由于地球内动力、外动力或者人为地质动力作用下导致的自然地质和人类的自然灾害突发事件。由于降水、地震等自然作用下&#xff0c;地质灾害在世界范围内频繁发生。我国除滑坡灾害外&#xff0c;还包括崩塌、泥石流、地面沉…

python并发 map函数的妙用

1.map是什么&#xff1f; map函数是Python中的一个内置函数&#xff0c;用于将一个函数应用到一个或多个可迭代对象的每个元素上&#xff0c;生成一个新的可迭代对象。它的一般形式是&#xff1a; map(function, iterable1, iterable2, ...)其中&#xff0c;function是一个函…

linux安装mysql5.7

linux安装mysql5.7 一、下载mysql5.7二、解压包介绍三、上传包到linux四、卸载mariadb五、安装mysql六、修改权限七、启动mysql八、使用过navicat创作不易&#xff0c;笔记不易&#xff0c;如觉不错&#xff0c;请三连&#xff0c;谢谢~~ 一、下载mysql5.7 去mysql官方下载&am…