我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue3 Teleport是如何工作的

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue3 Teleport是如何工作的

这篇文章主要讲解了“Vue3 Teleport是如何工作的”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue3 Teleport是如何工作的”吧!

Teleport 的目的

我首先要了解的是何时使用 Teleport 功能。

在处理较大的Vue项目时,有逻辑处理组织代码库是很重要的。但是,当处理某些类型的组件(如模式,通知或提示)时,模板HTML的逻辑可能位于与我们希望渲染元素的位置不同的文件中。

实际上,在很多时候,与我们的Vue应用程序的DOM完全分开处理时,这些元素的管理要容易得多。所有这些都是因为处理嵌套组件的位置,z-index和样式可能由于处理其所有父对象的范围而变得棘手。

这种情况就是 Teleport 派上用场的地方。我们可以在逻辑所在的组件中编写模板代码,这意味着我们可以使用组件的数据或  props。但是,然后完全将其渲染到我们Vue应用程序的范围之外。

如果不使用 Teleport,我们将不得不担心从子组件向DOM树传递逻辑的事件传播,但现在要简单得多。

Vue Teleport  是如何工作的

假设我们有一些子组件,我们想在其中触发弹出的通知。正如刚才所讨论的,如果将通知以完全独立的DOM树渲染,而不是Vue的根#app元素,则更为简单。

我们要做的第一件事是打开我们的index.html,并在之前添加一个<div>。

// index.html <body>    <div id="app"></div>    <div id='portal-target'></div> </body>

接下来,创建触发要渲染的通知的组件。

// VuePortals.vue <template>   <div class='portals'>     <button @click='showNotification'> Trigger Notification! </button>     <teleport to='#portal-target'>       <div v-if="isOpen" class='notification'>         This is rendering outside of this child component!       </div>     </teleport>   </div> </template>  <script> import { ref } from 'vue' export default {   setup () {     const isOpen = ref(false)      var closePopup      const showNotification = () => {       isOpen.value = true        clearTimeout(closePopup)        closePopup = setTimeout(() => {         isOpen.value = false       }, 2000)     }      return {       isOpen,       showNotification     }   } } </script>  <style scoped>   .notification {     font-family: myriad-pro, sans-serif;     position: fixed;     bottom: 20px;     left: 20px;     width: 300px;     padding: 30px;     background-color: #fff;   } </style>

在此代码段中,当按下按钮时,将渲染2秒钟的通知。但是,我们的主要目标是使用Teleport获取通知以在我们的Vue应用程序外部渲染。

如你所见,Teleport具有一个必填属性- to

to 需要 prop,必须是有效的查询选择器或 HTMLElement (如果在浏览器环境中使用)。指定将在其中移动<teleport>内容的目标元素

由于我们在#portal-target中传递了代码,因此 Vue会找到包含在index.html中的#portal-target div,它会把  Teleport 内的所有代码渲染到该div中。

下面是运行的结果:

Vue3 Teleport是如何工作的

检查元素和查看DOM可以清楚地知道发生了什么。

Vue3 Teleport是如何工作的

我们可以使用VuePortals组件中的所有逻辑,但是告诉我们的项目在其他地方渲染该模板代码!

感谢各位的阅读,以上就是“Vue3 Teleport是如何工作的”的内容了,经过本文的学习后,相信大家对Vue3 Teleport是如何工作的这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Vue3 Teleport是如何工作的

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue3之Teleport组件如何使用

这篇文章主要介绍了Vue3之Teleport组件如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue3之Teleport组件如何使用文章都会有所收获,下面我们一起来看看吧。Teleport 组件解决的问
2023-07-06

Vue3中key的作用和工作原理是什么

这篇文章主要介绍“Vue3中key的作用和工作原理是什么”,在日常操作中,相信很多人在Vue3中key的作用和工作原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue3中key的作用和工作原理是什么
2023-06-20

Flex是如何工作的

小编给大家分享一下Flex是如何工作的,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Flex是如何工作的该部分文档的内容是为用户提供关于Adobe?Flex工作机
2023-06-17

cdn是如何工作的

CDN(内容分发网络)是一种通过在全球分布式网络中放置服务器来加速内容传输的技术。它的工作原理如下:1. 缓存内容:CDN将原始内容(如网页、图片、视频等)缓存在离用户最近的服务器上。这些服务器通常被称为边缘节点。2. 内容路由:当用户请求
2023-08-25

Python中import是如何工作的

这篇“Python中import是如何工作的”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python中import是如何工
2023-07-06

React中Hooks是如何工作的

React中Hooks是如何工作的?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1. React Hooks VS 纯函数React Hook 说白了就是 Re
2023-06-15

Cassandra的索引是如何工作的

Cassandra 使用基于哈希的分布式哈希表来存储数据,并使用索引来快速查找数据。Cassandra 的索引工作方式如下:Secondary Indexes:Cassandra 支持二级索引,允许用户在表的非主键列上创建索引。当在非主键列
Cassandra的索引是如何工作的
2024-04-09

Node.js Socket.io库:它是如何工作的?

Node.js Socket.io库是一个用于创建实时应用程序的JavaScript库。它允许应用程序在客户端和服务器之间建立双向通信。
Node.js Socket.io库:它是如何工作的?
2024-02-11

Android中服务是如何工作的

在Android中,服务是一种可以在后台运行的组件,可以执行长时间运行的操作或监听外部事件。服务可以在应用程序中启动,停止或绑定到其他组件。服务可以通过以下方法启动:使用startService()方法启动服务。该方法会调用服务的onSt
Android中服务是如何工作的
2024-04-03

Python中的列表是如何工作的?

Python中的列表是一种非常常用的数据结构。它可以用于存储一系列的元素,并且允许进行各种操作,如添加、删除、修改和访问元素等。在本文中,我们将详细介绍Python中的列表是如何工作的,并附上具体的代码示例。Python中的列表是一个有序的
2023-10-22

编程热搜

目录