详解Vue3中Teleport的使用
在本文中,我们将介绍
- Teleport 的目的
- Teleport 的例子
- 一些很有意思的代码交互
Teleport 的目的
是什么时候以及使用这个 Teleport 功能。
在开发较大的 Vue 项目时应该以可重用的逻辑去组织代码。当处理某些类型的组件(如模式、通知或工具提示)时,模板 HTML 的逻辑可能不会和我们希望渲染元素处于相同的文件中。
实际上在大多数情况下,与 Vue 的 DOM 完全分开处理相比,处理这些元素要容易得多。因为嵌套组件的位置、z-index 和样式等这些东西,可能由于需要处理其所有父对象的作用域而变得棘手。
而这些正是 Teleport 的用武之地。我们可以在逻辑所在的组件中编写模板代码,因为这样我们可以使用组件的数据或 props。
如果不用 Teleport,我们还必须担心事件传播会把逻辑从子组件传递给 DOM 树。
Teleport 是怎样工作的
假设有一些子组件,我们想在其中触发弹出的通知。正如刚刚讨论的那样,如果将通知以完全独立的 DOM 树渲染,而不是 Vue 的根 #app 元素,会更加简单。
编辑 index.html 并在 </body> 之前添加一个 <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 class='notification'> This is rendering outside of this child ponent! </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 属性使用有效的 DOM 查询字符串,它可以是
- 元素的 ID
- 元素的类
- 数据选择器
- 响应查询字符串
由于我们在 #portal-target 中传递了代码,所以 Vue 程序将找到我们包含在 index.html 中的 #portal-target div,它会传送门户中的所有代码并将其渲染在该 div 中。
狼蚁网站SEO优化是结果
检查元素并查看 DOM,可以很清楚地了解都发生了什么。
我们可以使用 VuePortals 组建中的所有逻辑,需要告诉我们的项目渲染在其他地方的哪个模板代码。
以上就是详解Vue3中的Teleport的详细内容,更多关于Vue3 中的Teleport的资料请关注狼蚁SEO其它相关文章!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程