当前位置: 首页 > news >正文

Vue 3 的不同版本总结

Vue 3 的不同版本(例如 3.x 系列的多个次版本)在语法和特性上有一些变化和改进。以下是 Vue 3 中随着版本迭代的一些语法变化和新特性的总结。

1. Vue 3.0: 初始发布

主要特性:

  • 组合式 API (Composition API):引入 setup 函数,通过 ref
  • reactive 创建响应式数据,方便逻辑复用。
  • Proxy 响应式系统:相比 Vue 2 的 Object.defineProperty,Vue 3 使用 Proxy 来实现响应式数据,提高性能,支持嵌套对象。
  • Fragment 支持:允许组件返回多个根节点,解决了 Vue 2 只能有一个根元素的限制。
  • Teleport:新特性,允许将模板的一部分渲染到 DOM 的另一个位置。
  • Suspense:用于处理异步组件,加载前显示占位符。

语法变化:

  • data() 返回对象不再与 Vue 实例 this 绑定,响应式数据在组合式 API 中通过 refreactive 返回。
  • 生命周期钩子函数命名变化,如 mounted 对应 onMounted
import { ref, onMounted } from 'vue';setup() {const message = ref('Hello');onMounted(() => {console.log('Component mounted!');});return { message };
}

2. Vue 3.1: 性能优化与 API 改进

主要特性:

  • shallowRefshallowReactive:提供浅层响应式绑定,减少不必要的嵌套属性监听。
  • customRef:允许用户自定义 ref 的行为,例如节流或防抖。
  • 全局 provide/inject 的增强:新增 default 选项,可以为 inject 提供默认值。

语法变化:

  • 引入 customRef 的例子:
import { customRef } from 'vue';function useDebouncedRef(value, delay = 300) {let timeout;return customRef((track, trigger) => ({get() {track();return value;},set(newValue) {clearTimeout(timeout);timeout = setTimeout(() => {value = newValue;trigger();}, delay);}}));
}

3. Vue 3.2: 新的特性与增强

主要特性:

  • <script setup> 语法:一种更简洁的方式编写组合式 API,消除了 setup 函数的显式声明,直接在 <script> 内进行变量定义和逻辑编写。
  • v-memo 指令:用于缓存部分模板的渲染结果,减少不必要的重新渲染。
  • v-bind 的多个属性合并:允许通过 v-bind 同时传入多个对象,简化了复杂属性的绑定。
  • 模板宏:如 definePropsdefineEmits,用于在 <script setup> 中简化组件属性和事件的定义。

语法变化:

  • <script setup>
    • 通过 definePropsdefineEmits 简化属性和事件的定义,避免手动声明 propsemits
<script setup>
const props = defineProps(['title']);
const emit = defineEmits(['update']);
</script><template><div @click="emit('update')">{{ props.title }}</div>
</template>
  • v-memo 用法:
<template><div v-memo="[expensiveComputationResult]"><!-- 只在 expensiveComputationResult 改变时重新渲染 --></div>
</template>

4. Vue 3.3: defineModeldefineOptions 等改进

主要特性:

  • defineModel:用于在 <script setup> 中显式声明双向绑定模型的简洁方法。这个 API 更加简化了 v-model 的使用方式。
  • defineOptions:用于定义组件的选项,如 name,替代传统的 export default 方式。
  • $modelValue:对于 v-model 的值,现在可以通过 $modelValue 来访问和绑定。

语法变化:

  • defineModel 的用法
<script setup>
const modelValue = defineModel();
</script><template><input v-model="modelValue" />
</template>
  • defineOptions 的用法
<script setup>
defineOptions({name: 'MyComponent'
});
</script>

5. Vue 3.4 及更高版本:未来特性展望

随着 Vue 3 的继续迭代,社区和核心开发团队持续改进 API 和性能。以下是一些未来可能引入的特性:

  • Async Lifecycle Hooks:支持异步的生命周期钩子函数,以便在某些操作完成后继续组件生命周期。
  • 更优化的 Suspense:提高异步加载和渲染的体验。
  • 小型库优化:进一步减少框架的体积,提供更高效的运行时性能。

总结

随着 Vue 3 的演变,各个版本带来了很多增强功能和新的 API。以下是一些关键的变化总结:

  • Vue 3.0:引入组合式 API、Proxy 响应式系统、Fragment、Teleport 和 Suspense 等新特性。
  • Vue 3.1:引入 shallowRefshallowReactivecustomRef 等增强响应式系统的特性。
  • Vue 3.2<script setup> 简化组件定义,并新增 v-memo 指令优化渲染性能。
  • Vue 3.3defineModeldefineOptions 进一步简化 <script setup> 语法的使用。

每个版本带来的变化和改进都使得 Vue 3 更加灵活、强大和高效,在开发过程中应根据项目需求合理利用这些新功能。

1. Vue 3 响应式系统

Vue 3 的响应式系统是核心之一,依赖于 Proxy 代替 Vue 2 的 Object.defineProperty。这一改变不仅解决了 Vue 2 中无法监听数组和对象嵌套属性的问题,还带来了性能提升和更强的灵活性。

1.1 reactiveref 的工作机制

  • reactive:处理对象的响应式转换,返回的是对象的 Proxy。
  • ref:处理基本类型(如 numberstring)的响应式转换,包装成一个带有 .value 属性的对象。
const state = reactive({ count: 0, nested: { key: 'value' } });
const count = ref(0);state.count++; // 修改响应式对象,自动更新视图
count.value++; // 需要使用 .value 获取或修改 ref

1.2 响应式代理与深层嵌套的处理

  • Vue 3 的响应式代理通过 懒代理机制,在访问对象的嵌套属性时才对其进行代理。这种方式提高了初始渲染的性能。
  • 深层嵌套的对象在 Vue 3 中也能自动实现响应式,而 Vue 2 需要通过 $set 来处理深层嵌套。
const deepState = reactive({level1: {level2: {level3: { key: 'value' }}}
});deepState.level1.level2.level3.key = 'newValue'; // 自动响应

1.3 响应系统的缺陷与优化

  • 性能开销:由于 Proxy 监听一切操作,在频繁进行大数据量的操作时,可能会带来性能开销。
  • 优化建议:可以使用 shallowReactiveshallowRef 进行浅层的响应式处理,以减少代理的深度。
const shallowState = shallowReactive({ name: 'Vue' });

2. 组合式 API 的优势与深度理解

2.1 组合式 API 与 Options API 的对比

组合式 API 通过 setup 函数替代了 Vue 2 的 Options API 模式,让逻辑更加集中和复用。相比 Options API 将功能分散在 datamethodscomputed 中,组合式 API 提供了更灵活的组织方式。

组合式 API 优势:
  • 逻辑复用:通过封装 composables,能够轻松复用逻辑,而不用依赖 mixins。
  • 解耦逻辑:逻辑可以集中在一起,避免散乱在生命周期、数据等不同部分中。
  • TypeScript 支持更好:通过明确的类型声明,组合式 API 更容易与 TypeScript 结合。
// useCounter.js
import { ref } from 'vue';export function useCounter() {const count = ref(0);const increment = () => count.value++;return { count, increment };
}// 组件中使用
import { useCounter } from './useCounter';export default {setup() {const { count, increment } = useCounter();return { count, increment };}
}

2.2 setup 函数的执行机制

setup 函数是 Vue 3 组件逻辑的入口,它在组件实例创建之前被调用,因此无法在 setup 中使用 this 访问组件实例。

  • 返回值自动注入模板setup 函数返回的对象会被自动注入到模板中,无需手动挂载。
  • 生命周期钩子:可以在 setup 中使用组合式 API 提供的生命周期钩子,如 onMountedonBeforeUnmount,而不是传统的 mountedbeforeUnmount
import { onMounted, ref } from 'vue';export default {setup() {const message = ref('Hello Vue 3');onMounted(() => {console.log('Component mounted');});return { message };}
}

2.3 provideinject 的改进

Vue 3 中 provideinject 可以与组合式 API 结合使用,使得跨层级的状态传递更加简单。它们用于组件间的数据共享,避免过多的 prop 传递。

// Parent.vue
import { provide, ref } from 'vue';export default {setup() {const user = ref('Alice');provide('user', user);}
}// Child.vue
import { inject } from 'vue';export default {setup() {const user = inject('user');return { user };}
}

3. 异步渲染与 Suspense

Vue 3 引入了 异步渲染 的能力,通过组件异步加载提升性能。Vue 3 的 Suspense 组件允许在渲染期间处理异步操作,并显示加载状态。

<Suspense><template #default><AsyncComponent /></template><template #fallback><div>Loading...</div></template>
</Suspense><script>
export default {components: {AsyncComponent: defineAsyncComponent(() =>import('./AsyncComponent.vue'))}
}
</script>
  • Suspense:可以为异步组件的加载过程提供 fallback 界面,使用户体验更加平滑。
  • 异步组件加载:将不常用的组件异步加载,减小初始包体积,提高页面响应速度。

4. Vue 3 性能优化

4.1 Tree-shaking

Vue 3 的核心库经过模块化设计,支持 Tree-shaking,这意味着打包工具可以自动移除未使用的代码,从而减少打包体积。

  • 按需引入:在使用某些 Vue 特性(如 v-model)时,可以按需引入相关功能模块,避免整个框架加载。
  • 避免全局注册:尽量使用局部注册组件,而不是全局注册组件,减少全局依赖。
import { createApp } from 'vue';
import App from './App.vue';const app = createApp(App);
// 局部注册组件
app.component('MyComponent', MyComponent);

4.2 v-memo

Vue 3 新增的 v-memo 指令允许缓存渲染结果,避免不必要的重新渲染,适合一些复杂计算或昂贵的渲染场景。

<div v-memo="[expensiveComputation]">{{ expensiveComputation }}
</div>

4.3 shallowRefshallowReactive

在 Vue 3 中,shallowRefshallowReactive 提供了浅层的响应式代理。相比深度响应式,它们只处理第一层属性的响应式更新,适合优化大型对象或数组的性能。

const shallowState = shallowReactive({ name: 'Vue', details: { age: 3 } });
shallowState.details.age = 4; // 不会触发响应式更新

4.4 动态指令

Vue 3 的动态指令提升了性能,避免不必要的 watcher 注册。结合组合式 API,你可以在条件满足时,动态启用或禁用指令。

<div v-show="isVisible"></div>

5. 项目架构和设计思维

5.1 状态管理:Vuex 与 Pinia

对于中大型项目,状态管理是一个核心问题。Vue 3 推荐使用更轻量化的 Pinia 替代 Vuex,它提供了更简洁的 API 和组合式 API 的支持。

  • Pinia 的优势
    • 全局状态管理。
    • 支持模块化和热更新。
    • 更好的 TypeScript 支持。
import { defineStore } from 'pinia';export const useStore = defineStore('main', {state: () => ({ count: 0 }),actions: {increment() {this.count++;}}
});

5.2 组件设计与拆分

合理的组件拆分和复用是构建高效、可维护 Vue 项目的关键。确保每个组件只关注其特定职责,避免过度复杂化。

  • 单一职责原则:每个组件应该只处理一个具体任务,如按钮

组件、表单组件、列表组件等。

  • 提升性能:通过 v-forkey 优化列表渲染,避免不必要的重绘。

通过对 Vue 3 核心机制、响应式系统和组合式 API 的深入理解,能够帮助开发者更好地设计和优化应用,同时具备了应对复杂业务场景的能力。在实际开发中,除了掌握 API,还要善于利用 Vue 3 的各种性能优化技巧,确保项目的可维护性和高效运行。

相关文章:

Vue 3 的不同版本总结

Vue 3 的不同版本&#xff08;例如 3.x 系列的多个次版本&#xff09;在语法和特性上有一些变化和改进。以下是 Vue 3 中随着版本迭代的一些语法变化和新特性的总结。 1. Vue 3.0: 初始发布 主要特性&#xff1a; 组合式 API (Composition API)&#xff1a;引入 setup 函数&…...

在wpf 中 用mvvm 的方式 绑定 鼠标事件

在 wpf中, 如果遇到控件的 MouseEnter MouseLeave 属性时, 往往会因为有参数object sender, System.Windows.Input.MouseEventArgs e 很多人选择直接生成属性在后台, 破坏了MVVM, 这其实是不必要的. 我们完全可以用 xmlns:i“http://schemas.microsoft.com/xaml/behaviors” 完…...

TELEDYNE DALSA相机连接编码器

文章目录 对于线阵相机&#xff0c;欲令扫描拍照出来的图像不失真变形&#xff0c;则需要保证横向像素精度纵向像素精度&#xff0c;因此有下列等式成立&#xff1a; 现场的横向视野是650mm,横向实际像素是7663pixel&#xff0c;产线运动线速度为416.667mm/S,则可以计算出行频应…...

每天一个数据分析题(五百零八)- 机器学习模型

逻辑回归和支持向量机&#xff08;SVM&#xff09;都是经典的机器学习模型&#xff0c;逻辑回归和SVM的联系与区别&#xff0c;不正确的是&#xff1f; A. 二者都可以处理分类问题 B. 二者都可以增加不同的正则化项 C. 二者都是参数模型 D. SVM的处理方法是只考虑support v…...

leetcode栈与队列(一)-有效的括号

题目 . - 力扣&#xff08;LeetCode&#xff09; 给定一个只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] 的字符串 s &#xff0c;判断字符串是否有效。 有效字符串需满足&#xff1a; 左括号必须用相同类型的右括号闭合。左括号必须以正确的…...

鸿蒙NEXT开发-知乎评论小案例(基于最新api12稳定版)

注意&#xff1a;博主有个鸿蒙专栏&#xff0c;里面从上到下有关于鸿蒙next的教学文档&#xff0c;大家感兴趣可以学习下 如果大家觉得博主文章写的好的话&#xff0c;可以点下关注&#xff0c;博主会一直更新鸿蒙next相关知识 专栏地址: https://blog.csdn.net/qq_56760790/…...

重学SpringBoot3-集成Redis(十一)之地理位置数据存储

更多SpringBoot3内容请关注我的专栏&#xff1a;《SpringBoot3》 期待您的点赞&#x1f44d;收藏⭐评论✍ 重学SpringBoot3-集成Redis&#xff08;十一&#xff09;之地理位置数据存储 1. GEO 命令简介2. 项目环境配置2.1. 依赖引入2.2. Redis 配置 3. GEO 数据存储和查询实现3…...

Docker-compose 单节点管理、consul 注册中心、registrator、template

consul是一个基于分布式的服务发现和配置管理工具。它具有快速构建分布式架构&#xff0c;提供服务发现和服务注册功能。consul职能&#xff1a;1、自动发现、注册&#xff1b;2、自动配置&#xff1b;3、自动更新 服务发现&#xff1a;自动检查网络中的服务&#xff08;如数据…...

制药企业MES与TMS的数据库改造如何兼顾安全与效率双提升

*本图由AI生成 在全球制造业加速数字化转型的浪潮中&#xff0c;一家来自中国的、年营业额超过200亿元的制药企业以其前瞻性的视角和果断的行动&#xff0c;成为该行业里进行国产化改造的先锋。通过实施数据库改造试点项目&#xff0c;该企业实现了其关键业务系统MES&#xff0…...

Spring Boot比Spring多哪些注解

Spring Boot 是 Spring 框架的扩展&#xff0c;它旨在简化 Spring 应用程序的初始搭建以及开发过程。与 Spring 相比&#xff0c;Spring Boot 提供了许多额外的注解来进一步简化配置和开发工作。以下是 Spring Boot 特有的一些核心注解&#xff0c;这些注解在 Spring 中不可用&…...

985研一学习日记 - 2024.10.17

一个人内耗&#xff0c;说明他活在过去&#xff1b;一个人焦虑&#xff0c;说明他活在未来。只有当一个人平静时&#xff0c;他才活在现在。 日常 1、起床6:00√ 2、健身1个多小时 今天练了二头和背部&#xff0c;明天练胸和三头 3、LeetCode刷了3题 旋转图像&#xff1a…...

牛客SQL29详解 计算用户的平均次日留存率

牛客SQL29详解 计算用户的平均次日留存率 牛客SQL29详解 计算用户的平均次日留存率 叮嘟&#xff01;这里是小啊呜的学习课程资料整理。好记性不如烂笔头&#xff0c;今天也是努力进步的一天。一起加油进阶吧&#xff01; 牛客SQL29详解 计算用户的平均次日留存率 题目&#x…...

Redis --- 第四讲 --- 常用数据结构 --- 其他类型stream、bitmap……。补充内容scan命令。

通过前面的学习&#xff0c;我们已经学习了Redis最关键的五个数据结构&#xff1a;String、List、Hash、Set、ZSet。这五个数据结构应用广泛&#xff0c;频繁使用。 redis中包含的所有类型&#xff0c;下面将要介绍不常用的类型。 一、streams类型介绍 事件、epoll/IO多路复…...

Java多线程--实现跑马小游戏

线程的实现方式 继承Thread类&#xff1a;void run()方法没有返回值&#xff0c;无法抛异常实现Runnable接口&#xff1a;void run()方法没有返回值&#xff0c;无法抛异常实现Callable接口&#xff1a;V call() throws Exception 返回结果&#xff0c;能够抛异常 实现Callab…...

扫雷(C 语言)

目录 一、游戏设计分析二、各个步骤的代码实现1. 游戏菜单界面的实现2. 游戏初始化3. 开始扫雷 三、完整代码四、总结 一、游戏设计分析 本次设计的扫雷游戏是展示一个 9 * 9 的棋盘&#xff0c;然后输入坐标进行判断&#xff0c;若是雷&#xff0c;则游戏结束&#xff0c;否则…...

有源滤波器(一)

滤波器设计工具 | 滤波器设计向导 | Analog Devices 一种带通滤波器&#xff1a; 有源滤波器完美规避了这个带不带负载滤波参数变化的问题&#xff0c;但是有源滤波器只能处理小电流和小电压&#xff1a; 鼠标所指的电路图是一阶同相滤波器&#xff0c;右上角的是他的幅频特性…...

Flume面试整理-常见的Channel类型

Apache Flume提供了多种Channel(通道)类型,作为Source(源)和Sink(汇)之间的缓冲区,确保数据的可靠传输。不同类型的Channel提供了不同的性能和可靠性,适用于不同的应用场景。以下是Flume中常见的Channel类型及其特点: 1. Memory Channel ● 描述:Memory Channel将数…...

【前端】如何制作一个自己的网页(6)

接上文 网络中的图片 我们也可以在百度等网站搜索自己喜欢的图片。 此时对图片点击右键&#xff0c;选择【复制图片地址】&#xff0c;即可获得该图片的网络地址。 其实在HTML中&#xff0c;除了图片以外&#xff0c;我们还可以利用地址找到另一个网页。 如右图所示&#…...

Linux系统性能调优技巧

Linux系统性能调优是一个复杂而持续的过程&#xff0c;需要综合考虑硬件、软件、内核参数、进程管理等多个方面。以下是一些具体的调优技巧&#xff1a; 一、硬件优化 增加物理内存&#xff1a;内存不足时&#xff0c;系统会频繁进行交换&#xff08;swapping&#xff09;活动…...

数学建模算法与应用 第5章 插值与拟合方法

目录 5.1 插值方法 Matlab代码示例&#xff1a;线性插值 Matlab代码示例&#xff1a;样条插值 5.2 曲线拟合的线性最小二乘法 Matlab代码示例&#xff1a;线性拟合 5.3 最小二乘优化与多项式拟合 Matlab代码示例&#xff1a;多项式拟合 5.4 曲线拟合与函数逼近 Matlab代…...

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…...

在软件开发中正确使用MySQL日期时间类型的深度解析

在日常软件开发场景中&#xff0c;时间信息的存储是底层且核心的需求。从金融交易的精确记账时间、用户操作的行为日志&#xff0c;到供应链系统的物流节点时间戳&#xff0c;时间数据的准确性直接决定业务逻辑的可靠性。MySQL作为主流关系型数据库&#xff0c;其日期时间类型的…...

stm32G473的flash模式是单bank还是双bank?

今天突然有人stm32G473的flash模式是单bank还是双bank&#xff1f;由于时间太久&#xff0c;我真忘记了。搜搜发现&#xff0c;还真有人和我一样。见下面的链接&#xff1a;https://shequ.stmicroelectronics.cn/forum.php?modviewthread&tid644563 根据STM32G4系列参考手…...

P3 QT项目----记事本(3.8)

3.8 记事本项目总结 项目源码 1.main.cpp #include "widget.h" #include <QApplication> int main(int argc, char *argv[]) {QApplication a(argc, argv);Widget w;w.show();return a.exec(); } 2.widget.cpp #include "widget.h" #include &q…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)

设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile&#xff0c;新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

论文浅尝 | 基于判别指令微调生成式大语言模型的知识图谱补全方法(ISWC2024)

笔记整理&#xff1a;刘治强&#xff0c;浙江大学硕士生&#xff0c;研究方向为知识图谱表示学习&#xff0c;大语言模型 论文链接&#xff1a;http://arxiv.org/abs/2407.16127 发表会议&#xff1a;ISWC 2024 1. 动机 传统的知识图谱补全&#xff08;KGC&#xff09;模型通过…...

如何理解 IP 数据报中的 TTL?

目录 前言理解 前言 面试灵魂一问&#xff1a;说说对 IP 数据报中 TTL 的理解&#xff1f;我们都知道&#xff0c;IP 数据报由首部和数据两部分组成&#xff0c;首部又分为两部分&#xff1a;固定部分和可变部分&#xff0c;共占 20 字节&#xff0c;而即将讨论的 TTL 就位于首…...

dify打造数据可视化图表

一、概述 在日常工作和学习中&#xff0c;我们经常需要和数据打交道。无论是分析报告、项目展示&#xff0c;还是简单的数据洞察&#xff0c;一个清晰直观的图表&#xff0c;往往能胜过千言万语。 一款能让数据可视化变得超级简单的 MCP Server&#xff0c;由蚂蚁集团 AntV 团队…...

【Go语言基础【13】】函数、闭包、方法

文章目录 零、概述一、函数基础1、函数基础概念2、参数传递机制3、返回值特性3.1. 多返回值3.2. 命名返回值3.3. 错误处理 二、函数类型与高阶函数1. 函数类型定义2. 高阶函数&#xff08;函数作为参数、返回值&#xff09; 三、匿名函数与闭包1. 匿名函数&#xff08;Lambda函…...

音视频——I2S 协议详解

I2S 协议详解 I2S (Inter-IC Sound) 协议是一种串行总线协议&#xff0c;专门用于在数字音频设备之间传输数字音频数据。它由飞利浦&#xff08;Philips&#xff09;公司开发&#xff0c;以其简单、高效和广泛的兼容性而闻名。 1. 信号线 I2S 协议通常使用三根或四根信号线&a…...