问题产生
写项目时使用如elementui,vanui等组件库时,一些组件的子组件会有如图所示的,带有“class__xxx”这样的class,同时在写代码时为了样式不冲突,我们通常都会在每个组件的style上加上scoped,然后就导致更改上述子组件样式时无效。
上述样式我们使用常规css是无法修改的,如下代码所示。
.stats { .van-grid-item__content { border-radius: 10px !important; } }
解决方案
方案1 使用 /deep/
将上述css写成如下形式
.stats { .van-grid-item /deep/ .van-grid-item__content { border-radius: 10px !important; } }
/deep/ 是深度选择器,加上这个之后,就可以选中scope之后的子组件。
但是这个方法似乎只在低版本的Vue中有效,我使用的时候报如下错误
和我有一样问题的同学,请看下面的方法
方法2 使用 ::v-deep
在较新的版本中,使用::v-deep 代替了旧的 /deep/ ,因此将代码改为如下即可解决问题
.stats { .van-grid-item::v-deep .van-grid-item__content { border-radius: 10px !important; } }
注意,如果要改的元素没有父元素,则直接在开头加上 ::v-deep即可,如下所示
.stats { // 没有父元素的情况下 ::v-deep .van-grid-item__content { border-radius: 10px !important; } }
发表回复