欢迎来到代码驿站!

vue

当前位置:首页 > 网页前端 > vue

vue 无法覆盖vant的UI组件的样式问题

时间:2022-06-26 10:34:45|栏目:vue|点击:

无法覆盖vant的UI组件的样式

有时候UI组件提供的默认的样式不能满足项目的需要,就需要我们对它的样式进行修改,但是发现加了scoped后修改的样式不起作用。

解决方法

使用深度选择器,将scoped样式中的选择器“深入”,即影响子组件

<style scoped>
  .a >>> .b { /* ... */ }
</style>

以上的代码会编译成:

.a[data-v-f3f3eg9] .b { /* ... */ }

注意:如果你使用了Less或Sass等预处理器,可能无法>>>正确解析。

在这些情况下,您可以使用组合/deep/或::v-deep组合 - 两者都是别名,>>>并且工作完全相同。

使用Less或Sass等预处理器的写法如下:

.van-radio {
  /deep/ .van-radio__label {
    width: 500px;
  }
}

使用样式穿透,强制覆盖Vant原样式

使用Vant组件的时候,我们会发现在某些场合组件的原样式不符合我们的需求,这个时候我们就需要重写组件的原样式。

这个是组件的原样式

因为style标签添加了scope属性,scope会保护样式不被污染,这里要让我们自己的样式生效就必须使用样式穿透,由父样式穿透到子样式:

.w-all >>> .van-field__control{text-align: right;}

在浏览器可以看到

  • text-align:left那一栏已经被一条横线划掉,取而代之的是:

而这个,就是因为使用了样式穿透强制覆盖了原样式,从而实现我们需要的样式效果。

上一篇:vue拖拽添加的简单实现

栏    目:vue

下一篇:Vue3.x最小原型系统讲解

本文标题:vue 无法覆盖vant的UI组件的样式问题

本文地址:http://www.codeinn.net/misctech/206019.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有