vue3中解决组件间 css 层级问题最佳实践(Teleport的使用)

news/2025/2/24 5:56:18

定义:

<Teleport> 是 Vue 3 中引入的一个内置组件,用于将组件的内容渲染到 DOM 中的指定位置,而不受组件层级结构的限制。这在处理模态框、通知、下拉菜单等需要脱离当前组件层级的情况下非常有用。

通俗来说,Teleport的功能是将当前组件挂载到应用的顶层,与App组件同级。这样做的原因是,如果一个组件嵌套在Vue应用的内部,处理这个组件的定位、z-index以及样式会变得相当棘手。通过使用Teleport,可以轻松解决组件之间的CSS层级问题,使得样式管理更加简便有效。这种方式不仅简化了布局设计,还避免了因层级嵌套带来的样式冲突或覆盖问题。

使用:

   <Teleport to="body">
      <add-dialog>这是一个需要改变层级的弹窗</add-dialog>
   </Teleport>

<Teleport> 组件包含两个主要的属性:

  1. to: 指定目标容器,可以是一个 CSS 选择器字符串或一个 DOM 元素。

  2. disabled: 可选属性,用于控制是否禁用 Teleport。如果为 true,内容将不会被传送到目标容器,而是在原地渲染。

多个teleport还可以挂载到同一个元素下 

<Teleport to="body">
    <add-dialog>这是第一个需要改变层级的弹窗</add-dialog>
</Teleport>
<Teleport to="body">
    <user-dialog>这是第二个需要改变层级的弹窗</user-dialog>
</Teleport>

多个 <Teleport> 组件可以将其内容依次挂载到同一个目标元素上,按照先后顺序追加,后挂载的内容将放置于目标元素下的更靠后位置。

总结:

<Teleport> 是 Vue 3 中一个非常强大的工具,特别适合处理那些需要脱离当前组件层级的 UI 元素。通过 Teleport,你可以更灵活地控制组件的渲染位置,而不必担心 DOM 结构的限制。

拓展:

vue3中新增了哪些新的内置组件和特性?

Vue 3 引入了一些新的内置组件和特性,但并没有新增大量的 HTML 标签。Vue 3 的核心仍然是基于现有的 HTML 标签和自定义组件。以下是 Vue 3 中新增的主要内置组件和特性:

1. <Teleport>

  • 作用: 将组件的内容渲染到 DOM 中的指定位置,而不受组件层级结构的限制。

  • 使用场景: 模态框、通知、下拉菜单等需要脱离当前组件层级的情况。

  • 示例:

<Teleport to="body">
  <div class="modal">这是一个模态框</div>
</Teleport>

2. <Suspense>

  • 作用: 用于处理异步组件的加载状态,提供 fallback 内容(如加载动画)直到异步组件加载完成。

  • 使用场景: 异步组件、异步数据加载等。

  • 示例:

<Suspense>
  <template #default>
    <AsyncComponent />
  </template>
  <template #fallback>
    <div>加载中...</div>
  </template>
</Suspense>

3. <Fragment>

  • 作用: Vue 3 默认支持多根节点组件(Fragment),不再需要包裹一个单独的根元素。

  • 使用场景: 简化模板结构,避免不必要的包裹元素。

  • 示例:

<template>
  <div>第一个元素</div>
  <div>第二个元素</div>
</template>

4. v-model 的增强

  • Vue 3 对 v-model 进行了改进,支持多个 v-model 绑定,并且可以自定义修饰符。

  • 示例:

<ChildComponent v-model:title="pageTitle" v-model:content="pageContent" />

5. <script setup> 语法糖

  • 作用: 简化 Composition API 的使用,使代码更简洁。

  • 使用场景: 单文件组件(SFC)中使用 Composition API。

  • 示例:

<script setup>
import { ref } from 'vue';
const count = ref(0);
</script>

<template>
  <button @click="count++">{{ count }}</button>
</template>

6. <style scoped> 的改进

  • Vue 3 支持在 <style scoped> 中使用深度选择器 :deep(),用于样式穿透。

  • 示例:

css"><style scoped>
.parent :deep(.child) {
  color: red;
}
</style>

7. <Transition> 和 <TransitionGroup> 的改进

  • Vue 3 对过渡动画组件进行了优化,支持更多的动画场景和配置。

  • 示例:

<Transition name="fade">
  <div v-if="show">内容</div>
</Transition>

8. <KeepAlive> 的改进

  • Vue 3 对 <KeepAlive> 组件进行了增强,支持更细粒度的缓存控制。

  • 示例:

<KeepAlive :include="['ComponentA', 'ComponentB']">
  <component :is="currentComponent" />
</KeepAlive>

9. <component> 的改进

  • Vue 3 中 <component> 支持动态组件切换,并且可以结合 v-model 使用。

  • 示例:

<component :is="currentComponent" v-model="data" />

10. v-bind 的 CSS 变量支持

  • Vue 3 允许在 <style> 中使用 v-bind 绑定组件的响应式数据。

  • 示例:

<template>
  <div class="text">Hello</div>
</template>

<script setup>
import { ref } from 'vue';
const color = ref('red');
</script>

<style scoped>
.text {
  color: v-bind(color);
}
</style>

总结

Vue 3 并没有新增大量的 HTML 标签,而是通过引入新的内置组件(如 <Teleport> 和 <Suspense>)以及对现有特性的增强(如 v-model<script setup> 等)来提升开发体验和功能灵活性。这些新特性使得 Vue 3 更加强大和现代化。


http://www.niftyadmin.cn/n/5864005.html

相关文章

C/C++中的字符串

字符串表示方式&#xff1a; 在C语言中&#xff0c;字符串实际上是一个字符数组&#xff08;字节数组&#xff09;&#xff0c;并且以空字符 \0 结尾。例如&#xff0c;字符串 "RUNOOB" 实际上在内存中表示为 {R, U, N, O, O, B, \0}。这个 \0 终止符告诉标准库函数&…

[AI]【Comfyui】 生成基本流程图的步骤保姆记录

在进行深度学习模型或图像生成的过程中,创建流程图能够帮助清晰地表达模型的工作流程和数据流动。本文将为您介绍生成基本流程图的一般步骤,适用于常见的深度学习图像生成模型。以下是该流程图的基本步骤: 1. 创建 Load Checkpoint 节点 流程图的第一步通常是加载已经训练好…

网页制作07-html,css,javascript初认识のhtml添加多媒体

在网页中&#xff0c;&#xff0c;除了可以添加文本和图像之外还可以插入动画声音视频等媒体元素&#xff0c;如滚动效果、 Flash、 Active x以及midi声音文件等 一、设置滚动效果 1、滚动标记marquee 1)简介:使用marquee标记不仅可以滚动文字&#xff0c;也可以移动图片表格…

2025雅森北京展今天开幕,全景展现新能源汽车时代

推动汽车后市场全产业链向新向优转型升级 在2月21日举行的第36届中国国际汽车服务用品及设备展览会&#xff0c;中国国际新能源汽车技术、零部件及服务展览会&#xff08;雅森北京展CIAACE&#xff09;上&#xff0c;雅森国际总裁谢宇表示&#xff0c;当前正处在汽车行业新旧动…

鸿蒙5.0实战案例:基于ArkUI的验证码实现

往期推文全新看点&#xff08;文中附带全新鸿蒙5.0全栈学习笔录&#xff09; ✏️ 鸿蒙&#xff08;HarmonyOS&#xff09;北向开发知识点记录~ ✏️ 鸿蒙&#xff08;OpenHarmony&#xff09;南向开发保姆级知识点汇总~ ✏️ 鸿蒙应用开发与鸿蒙系统开发哪个更有前景&#…

使用Adobe Premiere Pro 2024软件实现多图片水平划出切换

使用Adobe Premiere Pro 2024软件实现多图片水平划出切换 步骤总结 纯PR新手操作&#xff0c;有误见谅。目标&#xff1a;试图使用PR2024实现图片间的水平滑入滑出切换&#xff0c;以对比相同内容不同图片之间的质量。实现效果&#xff1a;例如&#xff0c;有AB两图像&#xff…

【JavaEE进阶】Spring DI

欢迎关注个人主页&#xff1a;逸狼 创造不易&#xff0c;可以点点赞吗 如有错误&#xff0c;欢迎指出~ 依赖注⼊是⼀个过程&#xff0c;是指IoC容器在创建Bean时,去提供运⾏时所依赖的资源&#xff0c;⽽资源指的就是对象. 在上⾯程序案例中&#xff0c;我们使⽤了 Autowired 这…

libwebsockets交叉编译全流程

libwebsocket中的webscoket加密功能需要依赖于Openssl库因此需要提前准备好openssl开源库。 交叉编译openssl 下面演示源码方式交叉编译OpenSSL为动态库。 创建个Websocket文件夹&#xff0c;把后续的成果物均放在这个文件中&#xff0c;文件夹中创建子文件夹OpenSSL和libWeb…