style scoped属性的作用和原理、scoped穿透

官方文档:https://cn.vuejs.org/api/sfc-css-features.html

作用:实现组件的私有化,不对全局造成样式污染,表示当前style属性只属于当前模块。
原理:scoped会在DOM结构及css样式上加上唯一性的标记【data-v-something】属性,即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往往会造成更多的困难,需要增加额外的复杂度。
以TDesign组件为例,在使用scoped会出现 CSS 设置不起效的问题,无法通过 CSS 修改组件的样式。可以使用下面的方法来解决。

  1. 使用使用 sass 或 less 的样式穿透 //deep// 。

    /deep/.t-input--focused {
                box-shadow: none;
              }
    
  2. 使用 >>> 可以穿透 scoped 属性,修改其他第三方组件的样式。

    外层 >>> 第三方组件{}
    
  3. 使用两个 style 标签,一个带 scoped 属性,一个不带 scoped 属性,用来修改第三方组件的样式。

### `style scoped` 与普通 `style` 的区别 在 Vue 的单文件组件中,`<style scoped>` 普通 `<style>` 的主要区别在于样式的作用范围。`<style scoped>` 通过限定样式的作用范围,使得样式仅应用于当前组件的元素,从而避免全局样式污染命名冲突。这是通过 PostCSS 在编译时为组件的 DOM 元素对应的 CSS 选择器添加唯一的属性标识(如 `data-v-something`)实现的。例如: ```vue <template> <div class="example">hi</div> </template> <style scoped> .example { color: red; } </style> ``` 经过编译后,实际生成的样式如下: ```vue <template> <div class="example" data-v-f3f3eg9>hi</div> </template> <style> .example[data-v-f3f3eg9] { color: red; } </style> ``` 这种方式确保了样式不会影响到其他组件,从而实现了组件样式封装的效果 [^4]。 相比之下,普通 `<style>` 标签定义的样式是全局的,会作用于整个应用中的匹配元素。例如: ```vue <style> .example { color: red; } </style> ``` 该样式将作用于所有具有 `example` 类的元素,无论它们属于哪个组件。这种方式适用于定义全局样式或基础样式库,但需要谨慎管理类名以避免命名冲突 [^3]。 由于 `<style scoped>` 的作用域限制,父组件的样式不会渗透到子组件中,但子组件的根节点可以被父组件的样式影响。这种设计允许父组件从布局角度调整子组件的根元素样式。然而,在需要修改第三方组件或公共组件样式时,`scoped` 会带来额外的复杂度。为了解决这个问题,可以使用样式穿透技术,如 `/deep/`、`::v-deep` 或 `:deep()`,或者使用两个 `<style>` 标签,一个带 `scoped`,一个不带 `scoped` 来专门覆盖第三方组件的样式 。 在性能方面,`scoped` 会增加 CSS 选择器的长度,但由于现代浏览器对属性选择器的优化良好,其性能差异可以忽略不计。推荐在大多数情况下使用 `scoped` 以保持组件样式独立性。在复杂项目中,可以结合 CSS Modules(通过 `<style module>`)或使用预处理器(如 SCSS)来增强样式管理能力 [^3]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值