如何使用Vue3内置组件Teleport
这篇文章主要讲解了"如何使用Vue3内置组件Teleport",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"如何使用Vue3内置组件Teleport"吧!
目录
1、Teleport用法
2、完成模态对话框组件
3、组件的渲染
前言:
Vue 3.0
新增了一个内置组件 teleport
,主要是为了解决以下场景:
有时组件模板的一部分逻辑上属于该组件,而从技术角度来看,最好将模板的这一部分移动到 DOM
中 Vue app
之外的其他位置
场景举例:一个 Button
,点击后呼出模态对话框
这个模态对话框的业务逻辑位置肯定是属于这个 Button
,但是按照 DOM
结构来看,模态对话框的实际位置应该在整个应用的中间
这样就有了一个问题:组件的逻辑位置和DOM
位置不在一起
按照以前 Vue2
的做法,一般是使用 position: fixed
; 等CSS属性强行把对话框定位到了应用的中间位置,属于没有办法的办法,下面展示下 teleport
的基础用法。
1、Teleport用法
用法非常简单,只需要使用 to 这个属性就可以把组件渲染到想要的位置
// 渲染到body标签下 I'm a teleported modal!
也可以使用:
必须是有效的查询选择器或 HTMLElement
进一步
2、完成模态对话框组件
现在我们来封装一个标准的模态对话框
{{ title }}
使用的时候,只需要
这是一段内容,萧瑟仙贝。 // ...const visible = ref(false);const onDialog = () => { visible.value = !visible.value;};const onClose = () => { visible.value = false;};
更进一步
3、组件的渲染
上面我们已经把标准的模态对话框组件完成了,还有另外一种相似的,只需要展示少量文字的轻量级提示组件 Message
在上面的例子中,我们总是把 TDialog
组件写在使用的地方,但是这个 Messgae
组件,我们在想提示的时候使用一个js语句就把它呼出来,类似于下面的这样
// 呼出一个提示Message({ message: '这是一条Message消息' });
想使用一个函数呼出来,我们需要准备下这个函数,这个函数的作用就是完成组件的渲染。
const Message = options => { // 准备渲染容器 const container = document.createElement('div'); // 生成vnode const vnode = createVNode(MessageConstructor, options); // 渲染 render(vnode, container);};
MessageConstructor
是什么?就是我们的SFC(单文件组件):
在线 体验
查看 代码
感谢各位的阅读,以上就是"如何使用Vue3内置组件Teleport"的内容了,经过本文的学习后,相信大家对如何使用Vue3内置组件Teleport这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!