如何在 Vue 中使用 Teleport 移动部分模板

通常,当我们在 Vue 中创建组件时,它们自然会出现在我们期望的 DOM 结构中。但是,有时这没有意义。一个很好的例子就是模态框——通常,模态框应该出现在页面上所有内容的顶部——所以如果我们在逻辑上有意义的组件中创建它,它可能会出现在某些 HTML 元素后面或需要一些奇怪的 CSS 样式让它达到顶峰。

幸运的是,在 Vue 中有一种简单的方法可以解决这个问题,称为<Teleport>. 标签允许我们在<Teleport>组件中定义一些东西,然后在代码中我们想要的任何地方“传送”它。让我们看看它是如何工作的。

Teleport 在 Vue 中的工作原理#

假设我们在 Vue 中有一个名为的简单组件,Modal.vue其中包含一个模式。它看起来有点像这样:

<script>
export default {
    data() {
        return {
            display: false
        }
    }
}
</script>
<template>
    <button id="show-modal" @click="display == true ? display = false : display = true">Show Modal</button>
    <div class="modal" v-if="display">
        My Modal
    </div>
</template>

在我们的结构中,这种模式在我们的应用程序结构中非常深入:<根/><首页 /><模态/><孩子 /><购物车 />

由于Modal.vue在我们的结构中如此之深,它可能不会像我们想要的那样出现在我们其他内容的顶部。因此,理想情况下,我们希望它成为body标签的直接子代。使用<Teleport>,我们可以调整我们的组件以将其“传送”body标签的直接子代,如下所示:

<script>
export default {
    data() {
        return {
            display: false
        }
    }
}
</script>
<template>
    <button id="show-modal" @click="display == true ? display = false : display = true">Show Modal</button>
    <Teleport to="body">
        <div class="modal" v-if="display">
            My Modal
        </div>
    </Teleport>
</template>

to属性Teleport应该是一个有效的 CSS 选择器。现在我们的.modaldiv 将被传送为 body 的直接子代,所以它总是出现在顶部,而不是深深地嵌套在我们的 Vue 结构中。

禁用 Teleport 标签

我们可以使用该属性Teleport基于某些逻辑禁用标签。:disabled例如,我们可以myToggle使用以下代码检查设置为 true 的值:

<Teleport :disabled="myToggle"></Teleport>

上面,如果myToggle设置为true,则Teleport根本不起作用,这意味着我们只能在需要时启用它。因此,Teleport它是 Vue 中一个非常有用的标签,用于调整我们在何时地看到某些内容。在同一个 Vue 模板中使用多个标签也是可以的。Teleport