Vue深度作用选择器,挣脱Scoped束缚

<style>标签有scoped 属性时,它的 CSS只作用于当前组件中的元素。

<style scoped>
.example {
  color: red;
}
</style>

<template>
  <div class="example">hi</div>
</template>

转化结果为

<style>
.example[data-v-f3f3eg9] {
  color: red;
}
</style>

<template>
  <div class="example" data-v-f3f3eg9>hi</div>
</template>

使用 scoped 后,父组件的样式将不会渗透到子组件中。不过一个子组件的根节点会同时受其父组件的 scoped CSS 和子组件的 scoped CSS 的影响。这样设计是为了让父组件可以从布局的角度出发,调整其子组件根元素的样式

深度作用选择器

如果你希望 scoped样式中的一个选择器能够作用得“更深”,例如影响子组件

1.普通css你可以使用 >>>操作符:
<style scoped>
.a >>> .b { /* ... */ }
</style>

上述代码将会编译成:

.a[data-v-f3f3eg9] .b { /* ... */ }

这样b元素后面就不会再有属性选择器了

2.同样,要是scss可以使用::v-deep操作符:
<style lang='scss' scoped>
::v-deep .a { /* ... */ }
</style>
3.同样,要是less可以使用/deep/操作符:
<style lang='less' scoped>
/deep/ .a { /* ... */ }
</style>

Vue Loader官网

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Vue适用的深度选择器 在 Vue 的开发中,我们经常会用到外部组件库,例如 element,当使用 elemen...
    _孙小胖阅读 1,324评论 0 2
  • 一个web应用是离不开html、css与js,其中css充斥的整个web项目中。css它有一个特定,它是全局的。这...
    午后一小憩阅读 4,359评论 3 12
  • 前端开发面试题 面试题目: 根据你的等级和职位的变化,入门级到专家级,广度和深度都会有所增加。 题目类型: 理论知...
    怡宝丶阅读 2,606评论 0 7
  • 1. 介绍 浏览器可能是最广泛使用的软件。本书将介绍浏览器的工作原理。我们将看到,当你在地址栏中输入google....
    康斌阅读 2,060评论 7 18
  • 在现代化的 Web 开发中,CSS 还远未完美,这一点应该没有什么意外。 现今的项目通常都相当复杂,而 css 样...
    Vicky丶Amor阅读 1,265评论 0 7