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

相关文章

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me