当我们使用ant design vue组件库(点击跳转查看相关内容)时,经常会遇到样式无法修改的问题。这是因为 ant design vue
组件库的组件都具有自带的默认样式。
ant design vue UI
组件库)时,需要在局部组件中修改第三方组件库的样式,而又不想去除因scoped属性而造成的组件之间样式覆盖的问题。语法:
- 外层容器 >>> 组件 { }
从组件A穿透到组件B:
.A >>> .B { background: #fff
}
这两个常用的样式穿透的方式有两种,分别是 /deep/
与 ::v-deep
。
语法:
- 外层容器 /deep/ 组件 { }
- 外层容器 ::v-deep组件{ }
::v-deep
与/deep/
都是深度选择器(样式穿透),都能实现对组件内部的样式修改。
(两种方式没有很大的区别,如果用/deep/无效,则换用::v-deep试试,一般都是有效的。)
/* 从A组件深层穿透到B*/
.A /deep/ .B {border-color: #fff !important;
}
/* 从C组件深层穿透到button*/
.C ::v-deep button {height: 25px;
}
/* 深层穿透到switch*/
::v-deep .ant-switch ::after {height: 21px;width: 21px;
}
Less和sacc都可以进行 样式叠加(嵌套) 的写法,不过使用样式穿透的时候,写法会有些不一样。
/* 两层嵌套*/
.A ::v-deep {button {height: 25px;}.B ::after {height: 21px;width: 21px;}
}
注意: 确保样式嵌套层级正确。
文章发展线
本专题文章发展线 |
---|
css实现鼠标禁用(鼠标滑过显示红色禁止符号) |
css样式穿透(/deep/深度选择器) |
vue antd项目实战——修改ant design vue table组件的默认样式(css样式穿透) |
通过ant design vue的API属性实现不可控操作 |
vue antd项目实战——根据数据属性实现table表格中行的不可控操作 |
上一篇:网络技术展开型介绍(超详细)