scoped私有作用域和deep selector深度作用选择器

私有作用域

<style>标签上添加scoped属性,可以使样式只在当前组件生效,样式私有化,避免影响其他的组件,造成全局污染。

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

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

原理:
上述代码会通过PostCSS转换成:

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

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

通过给一个组件中的所有dom节点添加了一个唯一的data属性,并且给css选择器添加当前组件对应的data属性选择器来私有化样式

深度作用选择器

如果你希望 scoped 样式中的一个选择器能够作用得更深,影响到子组件,你可以使用 深度作用选择器>>>

<style scoped>
.a >>> .b { /* ... */ }
</style>

上述代码会转换成:

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

因为后面的那个类没加组件的data属性选择器,所以就能选到子组件里面的类了

别名

/deep/>>>的别名,有些像 SassLess 之类的预处理器无法正确解析 >>>,所以使用/deep/代替

<style scoped>
.a /deep/ .b { /* ... */ }
</style>

应用

平时写项目肯定会用第三方的组件,比如iviewelement-uimint-uivux-uiswiper等等,想要修改第三方组件的样式,但又不想去掉scoped属性,影响别的组件。

方式一

使用深度作用选择器:

<style scoped>
    外层组件类 >>> 第三方组件内部类 {
        样式
    }
</style>
方式二

一个组件中可以使用多个style,同时使用有 scoped 和非 scoped 样式:

<style>
/* 全局样式 */
/* 将修改第三方组件的样式写在这里 */
/* 组件的最外层标签定义一个唯一类,最好将样式都写在这个类名下,以防组件间互相影响 */
</style>

<style scoped>
/* 本地样式 */
</style>

提示

表层的一些样式,比如你在HTML页面中写出来标签的那些,如果加类名就可以实现修改样式,没必要使用深度选择器

文档

scoped

网站导航

网站导航

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

推荐阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明AI阅读 16,020评论 3 119
  • 在我至今患过的所有疾病中 我只承认孤独 这灵魂里的一根刺 锐度扎疼了我的肉体 我尝试过用冥想入药 在日出日落间调整...
    人造月球阅读 214评论 3 7
  • 我亲爱的倪先生, 首先,我得抱歉夏日对你的冷淡,躁热的空气让我偷偷去享受一个人的静谧。 因为九小时的火车距离,我没...
    twinklele阅读 706评论 0 3
  • 三 展无尘当然没有乖乖听话真的跑了八丈远,他顶多是竭力控制自己的手脚,让它们老实点就罢了。 只是,让零落颇为不解的...
    稻场旧事阅读 254评论 0 4