vue|vue 无法覆盖vant的UI组件的样式问题
目录
- 无法覆盖vant的UI组件的样式
- 解决方法
- 使用样式穿透,强制覆盖Vant原样式
- 这个是组件的原样式
- 在浏览器可以看到
无法覆盖vant的UI组件的样式 有时候UI组件提供的默认的样式不能满足项目的需要,就需要我们对它的样式进行修改,但是发现加了scoped后修改的样式不起作用。
解决方法
使用深度选择器,将scoped样式中的选择器“深入”,即影响子组件
.a >>> .b { /* ... */ }
以上的代码会编译成:
.a[data-v-f3f3eg9] .b { /* ... */ }
注意:如果你使用了Less或Sass等预处理器,可能无法>>>正确解析。
在这些情况下,您可以使用组合/deep/或::v-deep组合 - 两者都是别名,>>>并且工作完全相同。
使用Less或Sass等预处理器的写法如下:
.van-radio {/deep/ .van-radio__label {width: 500px; }}
使用样式穿透,强制覆盖Vant原样式 使用Vant组件的时候,我们会发现在某些场合组件的原样式不符合我们的需求,这个时候我们就需要重写组件的原样式。
这个是组件的原样式
文章图片
【vue|vue 无法覆盖vant的UI组件的样式问题】因为style标签添加了scope属性,scope会保护样式不被污染,这里要让我们自己的样式生效就必须使用样式穿透,由父样式穿透到子样式:
.w-all >>> .van-field__control{text-align: right; }
在浏览器可以看到
文章图片
text-align
:left那一栏已经被一条横线划掉,取而代之的是:
文章图片
而这个,就是因为使用了样式穿透强制覆盖了原样式,从而实现我们需要的样式效果。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
推荐阅读
- 利用vue3+threejs仿iView官网大波浪特效实例
- cordova+vueCordova的环境搭建(android),真机测试
- safari浏览器打不开该网页,因为无法连接到服务器
- Win10专业版下无法识别硬盘的5大原因及处理技巧
- Win8.1无法删除文件夹怎样办?
- wifi连接正常无法上网怎么办
- win10自动修复无法修复你的电脑
- 印象笔记无法同步你的笔记的4种处理方案_其它办公
- Win10专业版下Cortana无法运用“兴趣”是怎样回事?
- Win10系统手机无法发短信