vue中各种deep的区别解析

 更新时间:2024年10月12日 10:59:28   作者:蜡笔大杺  
在Vue3中,推荐使用::deep作为深度选择器,它比Vue2中的::v-deep语法更简洁,::v-deep、::deep、:deep()、>>>和/deep/都是用于穿透组件作用域的选择器,但Vue3更倾向于使用::deep或:deep(),感兴趣的朋友跟随小编一起看看吧

一共,::v-deep、::deep 和 :deep(),>>>,/deep/
从Vue 3开始,推荐使用 ::deep 而不是 ::v-deep

1. ::v-deep

::v-deep 是 Vue 2 中引入的深度选择器,在 Vue 3 中仍然可用,但不再是推荐的写法。它用于穿透作用域,将样式应用到子组件的元素上。

示例

<template>
  <div class="parent">
    <ChildComponent />
  </div>
</template>
<script setup>
import ChildComponent from './ChildComponent.vue';
</script>
<style scoped>
.parent ::v-deep .child-class {
  color: red;
}
</style>

2. ::deep

::deep 是 Vue 3 中推荐的深度选择器。它与 ::v-deep 功能相同,但语法更简洁。

示例

<template>
  <div class="parent">
    <ChildComponent />
  </div>
</template>
<script setup>
import ChildComponent from './ChildComponent.vue';
</script>
<style scoped>
.parent ::deep .child-class {
  color: red;
}
</style>

3. :deep()

:deep() 是 Vue 3 中推荐的另一种深度选择器。它是一个伪类,可以嵌套在其他选择器中使用,提供了更灵活的语法。

示例

<template>
  <div class="parent">
    <ChildComponent />
  </div>
</template>
<script setup>
import ChildComponent from './ChildComponent.vue';
</script>
<style scoped>
.parent :deep(.child-class) {
  color: red;
}
</style>

4 . >>>

在早期版本的Vue.js中,>>> 也被用来作为深度选择器。它的用法与 ::v-deep 类似,但是现在已经被 ::v-deep 或 ::deep 所取代。
示例:

.parent-class >>> .child-class {
  color: blue;
}

5. /deep/

/deep/ 也是早期Vue.js版本中的一个深度选择器。不过,随着Vue 2.6.0的发布,官方建议使用 ::v-deep 替代 /deep/。在某些情况下,特别是在使用某些构建工具或配置时,/deep/ 可能仍然有效,但并不推荐继续使用。
示例:

.parent-class /deep/ .child-class {
  color: green;
}

到此这篇关于vue中各种deep的区别的文章就介绍到这了,更多相关vue deep区别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

最新评论