如何丝滑的从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过渡。如果你感兴趣,欢迎评论 点赞和收藏!

相关推荐
天府之绝34 分钟前
uniapp 中使用uview表单验证时,自定义扩展的表单,在改变时无法触发表单验证处理;
开发语言·前端·javascript·vue.js·uni-app
xkxnq1 小时前
第二阶段:Vue 组件化开发(第 20天)
前端·javascript·vue.js
刘一说1 小时前
腾讯位置服务JavaScript API GL地图组件库深度解析:Vue生态中的地理空间可视化利器
javascript·vue.js·信息可视化·webgl·webgis
*才华有限公司*1 小时前
#从401到200:Spring Boot + Vue 静态资源访问全链路问题解决方案
vue.js·spring boot·后端
Tim_Van1 小时前
彻底解决:80 端口 GET/POST 正常,PUT 却报 ERR_CONNECTION_RESET?
java·vue.js·spring boot·ruoyi·若依
amazing-yuan1 小时前
彻底解决该 TS 报错 + 提升编译效率
前端·javascript·vue.js·typescript·vue·异常报错处理
dy17171 小时前
element-ui输入框换行符占位问题处理
vue.js·elementui
小马_xiaoen2 小时前
Vue3 实现超丝滑打字机效果组件 - 进阶
javascript·vue.js·ecmascript
神仙姐姐QAQ2 小时前
vue3更改.el-dialog__header样式不生效
前端·javascript·vue.js
AI_56782 小时前
Vue.js 深度开发指南:从数据绑定到状态管理的最佳实践
前端·javascript·vue.js