Vue 3.0 中令人激动的新功能:Portals+新的自定义指令API

本文主要是介绍Vue 3.0 中令人激动的新功能:Portals+新的自定义指令API,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一篇:Vue 3.0 中令人激动的新功能:Composition API

第二篇:Vue 3.0 中令人激动的新功能:Fragment+Suspense+多个v-model

这是最后一篇了,文章很长,但是都是干货,值得花费时间去看看学习了解。

Portals

Portals是一种特殊的组件,目的是在当前组件之外渲染某些内容。这也是React中原生实现的功能之一。这是React文档中关于portals的说法。

"Portals提供了一种第一流的方式,可以将子节点渲染到父组件的DOM层次结构之外的DOM节点中。"

这是一种非常好的处理modals、弹出窗口和一般要出现在页面顶部的组件的方式。通过使用portals,你可以确保没有任何一个主组件的CSS规则会影响到你想要显示的组件,并且免除了你用z-index做讨厌的hack的麻烦。

对于每一个Portals,我们需要指定它的目标目的地,在那里,Portals内容将被渲染。下面你可以看到portal-Vue库的实现,它在Vue 2中增加了这个功能。

<portal to="destination">  <p>This slot content will be rendered wherever thportal-target with name 'destination'    is  located.</p></portal>
<portal-target name="destination">  <!--  This component can be located anywhere in your App.  The slot content of the above portal component wilbe rendered here.  --></portal-target>

Vue 3将附带对 portals的开箱即用支持!

新的自定义指令API

自定义指令API将在Vue 3中略有改变,只是为了更好地与组件生命周期保持一致。这个变化应该会让新用户更容易理解和学习,因为它现在更直观了。

这是目前的自定义指令API。

const MyDirective = {  bind(el, binding, vnode, prevVnode) {},  inserted() {},  update() {},  componentUpdated() {},  unbind() {}}

…这就是Vue 3中的样子。

const MyDirective = {  beforeMount(el, binding, vnode, prevVnode) {},  mounted() {},  beforeUpdate() {},  updated() {},  beforeUnmount() {}, // new  unmounted() {}}

尽管这是一项重大更改,但它应该很容易被Vue兼容版本轻松涵盖。

这个API的改变目前在这个RFC中讨论,这意味着它可能会在未来发生变化。

Psst!你可以在我们的课程中学习如何掌握自定义指令。

总结

除了Composition API是Vue 3中最大的新API之外,我们还可以发现很多小的改进。我们可以看到,Vue正在向着更好的开发者体验和更简单、更直观的API发展。我们也很高兴看到,Vue团队决定将许多目前只能通过第三方库来实现的想法采纳到框架的核心。

上面的列表只包含了主要的API变化和改进。如果你对其他的东西很好奇,请一定要查看Vue RFCs仓库。

原文:https://vueschool.io/articles/vuejs-tutorials/exciting-new-features-in-vue-3/

这篇文章终于翻译完了,读完这三篇文章,我对Vue 3.0的更新大概就有数了。后续我还会继续更新Vue 3.0的更多教程,欢迎关注我。

推荐阅读:

扶我起来,我还能学:迎接 Vue 3.0

CSS 中calc()的完整指南(一)

Vue 3中令人激动的新功能:Composition API

掘金小册全网8折优惠入口

公众号后台回复【前端】加入群

好文和朋友一起看~

这篇关于Vue 3.0 中令人激动的新功能:Portals+新的自定义指令API的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/322993

相关文章

vue基于ElementUI动态设置表格高度的3种方法

《vue基于ElementUI动态设置表格高度的3种方法》ElementUI+vue动态设置表格高度的几种方法,抛砖引玉,还有其它方法动态设置表格高度,大家可以开动脑筋... 方法一、css + js的形式这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要

5分钟获取deepseek api并搭建简易问答应用

《5分钟获取deepseekapi并搭建简易问答应用》本文主要介绍了5分钟获取deepseekapi并搭建简易问答应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1、获取api2、获取base_url和chat_model3、配置模型参数方法一:终端中临时将加

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

Java中使用Java Mail实现邮件服务功能示例

《Java中使用JavaMail实现邮件服务功能示例》:本文主要介绍Java中使用JavaMail实现邮件服务功能的相关资料,文章还提供了一个发送邮件的示例代码,包括创建参数类、邮件类和执行结... 目录前言一、历史背景二编程、pom依赖三、API说明(一)Session (会话)(二)Message编程客

Java CompletableFuture如何实现超时功能

《JavaCompletableFuture如何实现超时功能》:本文主要介绍实现超时功能的基本思路以及CompletableFuture(之后简称CF)是如何通过代码实现超时功能的,需要的... 目录基本思路CompletableFuture 的实现1. 基本实现流程2. 静态条件分析3. 内存泄露 bug

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

详解如何在React中执行条件渲染

《详解如何在React中执行条件渲染》在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨... 目录引言什么是条件渲染?基础示例使用逻辑与运算符(&&)使用条件语句列表中的条件渲染总结引言在现代

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三