Vue中组件库生成的元素修改样式无效的解决方案
本文最后更新于 541 天前,其中的信息可能已经有所发展或是发生改变。

问题产生

写项目时使用如elementui,vanui等组件库时,一些组件的子组件会有如图所示的,带有“class__xxx”这样的class,同时在写代码时为了样式不冲突,我们通常都会在每个组件的style上加上scoped,然后就导致更改上述子组件样式时无效。

%title插图%num

 

 

 

 

 

 

上述样式我们使用常规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中有效,我使用的时候报如下错误

%title插图%num

 

 

 

 

 

和我有一样问题的同学,请看下面的方法

方法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;
  }
}

 



本站全部博文采用知识共享署名-非商业性使用 4.0 国际许可协议进行许可。

本文永久地址:https://blog.zixutech.cn/archives/631
本文作者:紫旭
暂无评论

发送评论 编辑评论


				
|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
颜文字
Emoji
小恐龙
花!
上一篇
下一篇