【前端框架】vue2和vue3的区别详细介绍

Vue 3 作为 Vue 2 的迭代版本,在性能、语法、架构设计等多个维度均有显著的变革与优化。以下详细剖析二者的区别:
响应式系统
Vue 2
- 实现原理:基于
Object.defineProperty()方法实现响应式。当一个 Vue 实例创建时,Vue 会遍历data选项中的所有属性,使用Object.defineProperty()将这些属性转换为getter/setter。这样,当这些属性的值发生变化时,Vue 能够检测到并更新与之绑定的 DOM。 - 局限性
- 无法检测对象属性的添加和删除:由于
Object.defineProperty()是对已有属性进行劫持,因此当给对象添加新属性或删除已有属性时,Vue 2 无法自动追踪这些变化。开发者需要使用Vue.set()或this.$set()方法来手动触发响应式更新。 - 数组变更检测问题:Vue 2 对数组的某些方法(如
push()、pop()、splice()等)进行了拦截,可以检测到这些操作并更新视图。但对于通过索引直接修改数组元素或修改数组长度的操作,Vue 2 无法自动触发响应式更新。
- 无法检测对象属性的添加和删除:由于
Vue 3
- 实现原理:采用
Proxy对象实现响应式系统。Proxy可以劫持整个对象,能够拦截对象的各种操作,包括属性的访问、赋值、删除等,从而实现更全面的响应式追踪。 - 优势
- 解决属性添加和删除的检测问题:使用
Proxy可以自动检测对象属性的添加和删除,无需像 Vue 2 那样使用额外的方法来触发响应式更新。 - 数组操作的完整响应式:对于数组的任何操作,
Proxy都能进行拦截,确保数组的变化能够被及时检测到并更新视图。
- 解决属性添加和删除的检测问题:使用
语法和 API
选项式 API(Options API)与组合式 API(Composition API)
- Vue 2:主要使用选项式 API,组件逻辑通过不同的选项(如
data、methods、computed、watch等)来组织。当组件变得复杂时,相关逻辑会分散在不同的选项中,导致代码难以阅读和维护。例如,一个组件中可能同时包含数据获取、表单验证、事件处理等多种逻辑,这些逻辑会被分散在不同的选项里,使得代码的关联性和复用性较差。 - Vue 3:引入了组合式 API,允许开发者根据逻辑功能来组织代码。开发者可以将相关的逻辑封装在一个函数中,然后在
setup函数中调用这些函数,提高了代码的复用性和可维护性。例如,将数据获取逻辑封装在一个useDataFetching函数中,在多个组件中都可以复用这个函数。同时,Vue 3 也保留了选项式 API,以兼容旧项目。
生命周期钩子
- Vue 2:具有多个生命周期钩子,如
beforeCreate、created、beforeMount、mounted、beforeUpdate、updated、beforeDestroy、destroyed等。这些钩子在组件的不同阶段被调用,开发者可以在这些钩子中执行特定的操作。 - Vue 3:对生命周期钩子进行了重命名,并且可以在组合式 API 中使用新的方式来调用。
beforeCreate和created可以在setup函数中实现,beforeDestroy改为beforeUnmount,destroyed改为unmounted。同时,还提供了新的钩子函数,如onMounted、onUpdated、onUnmounted等,使得在组合式 API 中使用生命周期钩子更加方便。
模板语法
- Vue 2:模板语法基本满足开发需求,但组件必须有一个根节点。例如:
<template><div><!-- 组件内容 --></div>
</template>
- Vue 3:支持多个根节点,模板结构更加灵活。例如:
<template><header><!-- 头部内容 --></header><main><!-- 主体内容 --></main><footer><!-- 底部内容 --></footer>
</template>
架构设计
TypeScript 支持
- Vue 2:对 TypeScript 的支持相对有限,使用 TypeScript 开发时需要编写较多的声明文件,类型推导不够友好,开发体验不够流畅。
- Vue 3:从设计之初就考虑了对 TypeScript 的支持,组合式 API 与 TypeScript 配合更加默契,能提供更好的类型推导和类型检查。例如,在
setup函数中可以更方便地定义和使用类型,减少了类型相关的错误。
新特性引入
- Vue 2:具备基本的组件化、响应式等功能,但缺乏一些处理复杂场景的高级特性。
- Vue 3:引入了一些新特性,如
Teleport和Suspense。- Teleport:可以将组件的一部分模板渲染到 DOM 的其他位置,方便处理模态框、提示框等场景。例如:
<template><div><button @click="showModal = true">Open Modal</button><Teleport to="body"><div v-if="showModal" class="modal"><!-- 模态框内容 --><button @click="showModal = false">Close Modal</button></div></Teleport></div>
</template>
- **Suspense**:用于处理异步组件的加载状态,使异步组件的加载管理更加简单。例如:
<template><Suspense><template #default><AsyncComponent /></template><template #fallback><p>Loading...</p></template></Suspense>
</template>
项目构建和生态系统
构建工具
- Vue 2:常用的构建工具是 Vue CLI,它基于 Webpack 进行项目构建。Webpack 功能强大,但配置复杂,启动和热更新速度相对较慢。
- Vue 3:除了 Vue CLI 外,Vite 成为了 Vue 3 项目的推荐构建工具。Vite 具有快速冷启动、即时热更新等优点,能显著提升开发效率。Vite 利用浏览器的原生 ES 模块导入功能,在开发阶段无需打包,直接提供源码给浏览器,从而实现快速启动。
生态系统兼容性
- Vue 2:拥有庞大的生态系统,有大量的插件和库可供使用。但部分插件可能需要一定的时间来适配 Vue 3。
- Vue 3:生态系统在不断发展和完善,越来越多的插件和库开始支持 Vue 3,同时一些新的生态工具也在不断涌现。例如,Pinia 作为新一代的状态管理库,在 Vue 3 中得到了广泛应用。
相关文章:
【前端框架】vue2和vue3的区别详细介绍
Vue 3 作为 Vue 2 的迭代版本,在性能、语法、架构设计等多个维度均有显著的变革与优化。以下详细剖析二者的区别: 响应式系统 Vue 2 实现原理:基于 Object.defineProperty() 方法实现响应式。当一个 Vue 实例创建时,Vue 会遍历…...
CMake管理依赖实战:多仓库的无缝集成
随着软件复杂度的增加,单个项目可能需要依赖多个外部库或模块。这些依赖项可能是来自不同的代码仓库,如ATest和BTest。为了实现高效的依赖管理,CMake提供了多种方式来处理这种多仓库的情况。下面我们将详细介绍几种常见的方法,并通…...
Touchgfx 编写下载算法文件(.stldr)
一)下载算法文件主要参考官方的STM32 ST-LINK Utility模板:(文件所在位置如下:) C:\Program Files (x86)\STMicroelectronics\STM32 ST-LINK Utility\ST-LINK Utility\ExternalLoader\M25P64_STM3210E-EVAL\Project\MD…...
回不去的乌托邦
回不去的乌托邦 坐在电脑面前愣神间已至深夜,依然睡意不起。 相比于带着疲惫入睡,伏案发呆更令人惬意。想起最近在自媒体上看到的一句话“最顶级的享受变成了回不去的乌托邦”。 “这是兄弟们最后一次逛校园了,我拍个照”。我的记忆力总是用在…...
如何在 SpringBoot 项目使用 Redis 的 Pipeline 功能
本文是博主在批量存储聊天中用户状态和登陆信息到 Redis 缓存中时,使用到了 Pipeline 功能,并对此做出了整理。 一、Redis Pipeline 是什么 Redis 的 Pipeline 功能可以显著提升 Redis 操作的性能,性能提升的原因在于可以批量执行命令。当我…...
Linux----线程
一、基础概念对比 特性进程 (Process)线程 (Thread)资源分配资源分配的基本单位(独立地址空间)共享进程资源调度单位操作系统调度单位CPU调度的最小单位创建开销高(需复制父进程资源)低(共享进程资源)通信…...
实现rolabelimg对于dota格式文件的直接加载和保存
在本篇博客中,我们将讲解如何修改roLabelImg.py文件,使其能够直接加载和保存Dota格式的标注文件(txt)以替换掉复杂的xml文件。通过对源代码的修改,我们将实现支持加载并保存Dota格式标注数据,以便与roLabel…...
bboss v7.3.5来袭!新增异地灾备机制和Kerberos认证机制,助力企业数据安全
ETL & 流批一体化框架 bboss v7.3.5 发布,多源输出插件增加为特定输出插件设置记录过滤功能;Elasticsearch 客户端新增异地双中心灾备机制,提升框架高可用性;Elasticsearch client 和 http 微服务框架增加对 Kerberos 认证支持…...
华为昇腾服务器固件Firmware、驱动Drive、CANN各自的作用与联系?
文章目录 **1. 固件(Firmware)****2. 驱动(Driver)****3. CANN(Compute Architecture for Neural Networks)****三者关系****典型问题定位** 华为昇腾服务器的固件、驱动和CANN是支撑其AI计算能力的核心组件…...
MySQL 视图入门
一、什么是 MySQL 视图 1.1 视图的基本概念 在 MySQL 中,视图是一种虚拟表,它本身并不存储实际的数据,而是基于一个或多个真实表(基表)的查询结果集。可以把视图想象成是一个预定义好的查询语句的快捷方式。当你查询…...
算法很美笔记(Java)——动态规划
解重叠子问题(当前解用到了以前求过的解) 形式:记忆型递归或递推(dp) 动态规划本质是递推,核心是找到状态转移的方式,也就是填excel表时的逻辑(填的方式),而…...
C++ ——继承
体现的是代码复用的思想 1、子类继承父类,子类就拥有了父类的特性(成员方法和成员属性) 2、已存在的类被称为“基类”或者“父类”或者“超类”;新创建的类被称为“派生类”或者“子类” 注意: (1&#…...
LeetCode 热题 100 283. 移动零
LeetCode 热题 100 | 283. 移动零 大家好,今天我们来解决一道经典的算法题——移动零。这道题在LeetCode上被标记为简单难度,要求我们将数组中的所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。下面我将详细讲解解题思路,…...
游戏引擎学习第116天
回顾昨天的工作 本次工作内容主要集中在游戏开发的低级编程优化,尤其是手动优化软件渲染。工作目的之一是鼓励开发者避免依赖外部库,而是深入理解代码并进行优化。当前阶段正进行SIMD(单指令多数据)优化,使用Intel推荐…...
react(9)-redux
使用CRA快速创建react项目 npx create-react-app react-redux 安装配套工具 npm i reduxjs/toolkit react-redux 启动项目 在创建项目时候会出现一个问题 You are running create-react-app 5.0.0, which is behind the latest release (5.0.1). We no longer support…...
Linux内核实时机制7 - 实时改造机理 - 软中断优化下
Linux内核实时机制7 - 实时改造机理 - 软中断优化下 https://blog.csdn.net/u010971180/article/details/145722641以下分别以Linux4.19、Linux5.4、Linux5.10、Linux5.15 展开分析,深入社区实时改造机理的软中断优化过程。https://blog.csdn.net/weixin_41028621/article/det…...
企业知识管理平台重构数字时代知识体系与智能服务网络
内容概要 现代企业知识管理平台的演进呈现出全生命周期管理与智能服务网络构建的双重特征。通过四库体系(知识采集库、加工库、应用库、评估库)的协同运作,该系统实现了从知识沉淀、结构化处理到价值释放的完整闭环。其中,知识图…...
大数据组件(四)快速入门实时数据湖存储系统Apache Paimon(3)
Paimon的下载及安装,并且了解了主键表的引擎以及changelog-producer的含义参考: 大数据组件(四)快速入门实时数据湖存储系统Apache Paimon(1) 利用Paimon表做lookup join,集成mysql cdc等参考: 大数据组件(四)快速入门实时数据…...
SVN把英文换中文
原文链接:SVN设置成中文版本 都是英文,换中文 Tortoise SVN 安装汉化教程(乌龟SVN) https://pan.quark.cn/s/cb6f2eee3f90 下载中文包...
Ubuntu 的RabbitMQ安装
目录 1.安装Erlang 查看erlang版本 退出命令 2. 安装 RabbitMQ 3.确认安装结果 4.安装RabbitMQ管理界面 5.启动服务并访问 1.启动服务 2.查看服务状态 3.通过IP:port 访问界面 4.添加管理员用户 a)添加用户名:admin,密码࿱…...
逻辑回归:给不确定性划界的分类大师
想象你是一名医生。面对患者的检查报告(肿瘤大小、血液指标),你需要做出一个**决定性判断**:恶性还是良性?这种“非黑即白”的抉择,正是**逻辑回归(Logistic Regression)** 的战场&a…...
MongoDB学习和应用(高效的非关系型数据库)
一丶 MongoDB简介 对于社交类软件的功能,我们需要对它的功能特点进行分析: 数据量会随着用户数增大而增大读多写少价值较低非好友看不到其动态信息地理位置的查询… 针对以上特点进行分析各大存储工具: mysql:关系型数据库&am…...
PPT|230页| 制造集团企业供应链端到端的数字化解决方案:从需求到结算的全链路业务闭环构建
制造业采购供应链管理是企业运营的核心环节,供应链协同管理在供应链上下游企业之间建立紧密的合作关系,通过信息共享、资源整合、业务协同等方式,实现供应链的全面管理和优化,提高供应链的效率和透明度,降低供应链的成…...
pam_env.so模块配置解析
在PAM(Pluggable Authentication Modules)配置中, /etc/pam.d/su 文件相关配置含义如下: 配置解析 auth required pam_env.so1. 字段分解 字段值说明模块类型auth认证类模块,负责验证用户身份&am…...
高等数学(下)题型笔记(八)空间解析几何与向量代数
目录 0 前言 1 向量的点乘 1.1 基本公式 1.2 例题 2 向量的叉乘 2.1 基础知识 2.2 例题 3 空间平面方程 3.1 基础知识 3.2 例题 4 空间直线方程 4.1 基础知识 4.2 例题 5 旋转曲面及其方程 5.1 基础知识 5.2 例题 6 空间曲面的法线与切平面 6.1 基础知识 6.2…...
【论文笔记】若干矿井粉尘检测算法概述
总的来说,传统机器学习、传统机器学习与深度学习的结合、LSTM等算法所需要的数据集来源于矿井传感器测量的粉尘浓度,通过建立回归模型来预测未来矿井的粉尘浓度。传统机器学习算法性能易受数据中极端值的影响。YOLO等计算机视觉算法所需要的数据集来源于…...
镜像里切换为普通用户
如果你登录远程虚拟机默认就是 root 用户,但你不希望用 root 权限运行 ns-3(这是对的,ns3 工具会拒绝 root),你可以按以下方法创建一个 非 root 用户账号 并切换到它运行 ns-3。 一次性解决方案:创建非 roo…...
论文浅尝 | 基于判别指令微调生成式大语言模型的知识图谱补全方法(ISWC2024)
笔记整理:刘治强,浙江大学硕士生,研究方向为知识图谱表示学习,大语言模型 论文链接:http://arxiv.org/abs/2407.16127 发表会议:ISWC 2024 1. 动机 传统的知识图谱补全(KGC)模型通过…...
【Web 进阶篇】优雅的接口设计:统一响应、全局异常处理与参数校验
系列回顾: 在上一篇中,我们成功地为应用集成了数据库,并使用 Spring Data JPA 实现了基本的 CRUD API。我们的应用现在能“记忆”数据了!但是,如果你仔细审视那些 API,会发现它们还很“粗糙”:有…...
【论文阅读28】-CNN-BiLSTM-Attention-(2024)
本文把滑坡位移序列拆开、筛优质因子,再用 CNN-BiLSTM-Attention 来动态预测每个子序列,最后重构出总位移,预测效果超越传统模型。 文章目录 1 引言2 方法2.1 位移时间序列加性模型2.2 变分模态分解 (VMD) 具体步骤2.3.1 样本熵(S…...
