scoped私有作用域和deep|scoped私有作用域和deep selector深度作用选择器
私有作用域
【scoped私有作用域和deep|scoped私有作用域和deep selector深度作用选择器】在标签上添加
scoped
属性,可以使样式只在当前组件生效,样式私有化,避免影响其他的组件,造成全局污染。
hi
.example {
color: red;
}
原理:
上述代码会通过
PostCSS
转换成:
hi
.example[data-v-f3f3eg9] {
color: red;
}
通过给一个组件中的所有
dom
节点添加了一个唯一的data
属性,并且给css
选择器添加当前组件对应的data
属性选择器来私有化样式深度作用选择器 如果你希望
scoped
样式中的一个选择器能够作用得更深,影响到子组件,你可以使用 深度作用选择器>>>
。
.a >>> .b { /* ... */ }
上述代码会转换成:
.a[data-v-f3f3eg9] .b { /* ... */ }
因为后面的那个类没加组件的
data
属性选择器,所以就能选到子组件里面的类了别名
/deep/
是>>>
的别名,有些像 Sass
,Less
之类的预处理器无法正确解析 >>>
,所以使用/deep/
代替
.a /deep/ .b { /* ... */ }
应用 平时写项目肯定会用第三方的组件,比如
iview
,element-ui
,mint-ui
,vux-ui
,swiper
等等,想要修改第三方组件的样式,但又不想去掉scoped
属性,影响别的组件。方式一 使用深度作用选择器:
外层组件类 >>> 第三方组件内部类 {
样式
}
方式二 一个组件中可以使用多个
style
,同时使用有 scoped 和非 scoped 样式:
/* 全局样式 */
/* 将修改第三方组件的样式写在这里 */
/* 组件的最外层标签定义一个唯一类,最好将样式都写在这个类名下,以防组件间互相影响 *//* 本地样式 */
提示 表层的一些样式,比如你在HTML页面中写出来标签的那些,如果加类名就可以实现修改样式,没必要使用深度选择器
文档 scoped
网站导航 网站导航
推荐阅读
- 私有化轻量级持续集成部署方案--03-部署web服务(下)
- Android7.0|Android7.0 第三方应用无法访问私有库
- VM|VM ware 的 harbor 私有仓库搭建 (Ubuntu16.04)
- 1.块级作用域绑定
- 进阶-pod|进阶-pod 私有库命令
- 用|用 Satis 处理私有资源包(使用 satis 搭建 Composer 私有库)
- OkHttp的Internal让外部对象可以访问私有方法
- Laravel+vue公有/私有广播实战
- Solidity|Solidity - 变量作用域
- 组件化|组件化 私有库遇到的问题