如何丝滑的从Vue2向Vue3的过渡(上篇)

Vue3的到来开启了一系列增强和突破性功能的新时代。从Vue2到Vue3的这一进化步骤为开发者提供了一系列机会,能够让我们站在Web开发趋势的前沿,充分发挥这个卓越框架的潜力。今天我将与大家分享,Vue3带来的宏伟进步。在迁移过程中如何处理已弃用和被淘汰的部分,以及如何丝滑的从Vue2向Vue3过渡。

Vue3的新特性都有哪些呢?

1. Composition API(组合式API)


组合式API提供了一种灵活的方式来组织组件逻辑,更易于通过更好的类型检查在组件之间重用代码。与选项式API相比,组合式API更易于维护。

2. 更好的类型支持

Vue3的代码基于TypeScript完全编写,具有自动生成的类型定义。它具有更好的类型推断和对TypeScript的可选链和空值合并运算符的支持。

3.改进的虚拟DOM算法,多根节点

Vue3中的虚拟DOM已经完全重新设计。它利用了一个新的差异算法,并通过基于编译器的优化加速渲染过程。 在Vue3中,我们可以为单个组件创建多个根节点,而在Vue2中这是不可行的。

4.传送门(Teleport)

<Teleport> 是一个内置组件,允许我们将组件模板的一部分"传送"到存在于该组件的DOM层次结构之外的DOM节点中。<Teleport>to 属性期望一个CSS选择器字符串或一个实际的DOM节点。当<Teleport> 组件被挂载时,传送到目标的节点必须已经存在于DOM中。如下面代码所示:

这段代码使用了Vue3的组件 <demo-component> 包含了一个 <teleport> 组件,而 <teleport> 又包裹了一个名为 <pop-up> 的子组件。这段代码的主要目的是将 <pop-up> 组件的内容传送(teleport)到页面中具有 id="teleport-area" 的 DOM 节点内。

Vue 3已弃用和移除的内容

Filters:

在Vue 3中,已移除Filters。相反,我们可以使用方法或计算属性。您可以参考下面的示例:

vue2中的filters函数

Vue3使用计算属性进行了替换

v-model

在Vue 3中,v-model的prop和事件默认名称已更改:

  • PROP: value ⟶ modelValue;
  • EVENT: input ⟶ update:modelValue;
  • 破坏性的变更: v-bind的.sync修饰符和组件模型选项已被移除,用v-model上的参数替代
  • 新增: 可以在同一组件上进行多个v-model绑定 ;创建自定义v-model修饰符的能力

Vue2中的v-model

Vue3中V-model

作用域插槽

在Vue 3中,作用域插槽具有不同的语法。要识别插槽名称,请使用v-slot指令或其#简写。

Vue2 slot的使用

Vue3 slot的使用

Key属性

Vue3 在v-if/v-else/v-else-if分支上不再需要key,因为Vue现在会自动生成唯一的key。 在<template v-for>上的key应该放在<template>标签上(而不是其子元素上)。

v-if与v-for的优先级

  • 在Vue 2中: 在同一个元素上同时使用v-if和v-for时,v-for会优先于v-if。
  • 在Vue 3中: v-if将始终优先于v-for。

以上是今天的分享内容,由于篇幅太长的原因,下一篇将继续分享 如何丝滑的从Vue2向Vue3过渡。如果你感兴趣,欢迎评论 点赞和收藏!

相关推荐
秃头网友小李1 天前
前端难点:keep-alive 缓存什么?RouterView 的 key 为什么要带 scopeId?
前端·vue.js
徐小夕1 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
奋斗吧程序媛2 天前
补充一个小知识点:有关@click.native
前端·vue.js
英勇无比的消炎药2 天前
一行命令背后:TinyRobot CLI 如何重构 AI 对话接入的效率范式
vue.js·aigc
jay神2 天前
基于 FastAPI + Vue 的宠物领养管理系统
前端·vue.js·python·毕业设计·fastapi·宠物
一杯奶茶¥2 天前
水果销售网站 CRM客户信息管理系统 超市管理系 酒店管理系统 健身房管理系统 在线音乐网站 校园招聘系统
java·vue.js·spring boot·mysql·spring·java项目
英勇无比的消炎药2 天前
一站式搞定品牌风格:TinyRobot 主题定制从入门到精通
vue.js
尽欢i2 天前
Vue3 customRef 封神教程:防抖、本地存储、自动埋点一套搞定,模板干干净净
前端·javascript·vue.js
因_崔斯汀2 天前
Vue 模板编译:HTML 是怎么变成 JS 的?
前端·vue.js
英勇无比的消炎药2 天前
样式随心定制:TinyRobot 样式覆写与 CSS 变量实战解析
vue.js