[Vue] 解决vant 无法修改组件的样式问题(deep、>>>) | 您所在的位置:网站首页 › vue中css样式不生效 › [Vue] 解决vant 无法修改组件的样式问题(deep、>>>) |
首先我们应该知道在scoped里修改是无法做到修改vant样式的,这是外部引入的样式,下面的方法可以解决修改vant样式的同时,使用scoped,防止样式污染 第一种:加上父级自己定义的类名.common-container >>> (只作用于css) .common-container >>> .van-pull-refresh__head { color: #fff; }第二种:有些Sass 、Less之类的预处理器无法正确解析 >>>。可以使用 /deep/操作符或 ::v-deep 操作符( 两者都是>>> 的别名) /deep/ .van-list__error-text, /deep/ .van-list__finished-text, /deep/ .van-list__loading , /deep/ .van-pull-refresh__head , /deep/ .van-loading__text { color: #fff; } .common-container{ &::v-deep .van-pull-refresh__head{ color: #fff; // ... } }如果你希望 scoped 样式中的一个选择器能够作用得“更深”,例如影响子组件,你可以使用 >>> 操作符: handlebars .a >>> .b { /* ... */ } 上述代码将会编译成: handlebars .a[data-v-f3f3eg9] .b { /* … */ } 有些像 Sass 之类的预处理器无法正确解析 >>>。这种情况下你可以使用 /deep/ 或 ::v-deep 操作符取而代之——两者都是 >>> 的别名,同样可以正常工作。 参考 https://blog.csdn.net/idomyway/article/details/94659598 |
CopyRight 2018-2019 实验室设备网 版权所有 |