vue-cli —— 如何局部修改Element样式


Posted in Javascript onOctober 22, 2020

最近在做vue项目时用到了Element,发现这玩意儿用起来很舒服,很新颖,上手也很快,而且效果足够酷炫。但是后面发现一个很大的问题,那就是Element的样式有限,这极大地限制了项目的应用广度,所以我们有必要对Element内部的CSS进行一定的覆盖,来改变其样式。在修改Element样式时,遇到了一些问题,这里简单做一些记录,便于以后查阅。

我在用el-switch做开关切换时,使用默认样式:

代码如下:

vue-cli —— 如何局部修改Element样式

效果:

vue-cli —— 如何局部修改Element样式

现在我想把蓝色字体改为其他颜色,但是我发现无论我如何修改样式,界面始终没有任何变化,所以我想到可能是需要覆盖Element默认的el-switch样式。于是,我找呀找,找呀找,终于在node_modules/element-ui/lib/theme-chalk下找到了对应的默认样式,如下所示:

Element默认样式:

vue-cli —— 如何局部修改Element样式

vue-cli —— 如何局部修改Element样式

于是,我想着把,这下问题能解决了,我开开心心地在自己的组件里把对应的样式覆盖了:

vue-cli —— 如何局部修改Element样式

我鸡冻的点了一下刷新,发现并没有什么卵用,还是以前熟悉的面孔:

vue-cli —— 如何局部修改Element样式

我不服气,继续百度,似乎看到一丝曙光,按照网上说的,在样式的color后面加了 !important ,然后心情美丽地刷新了一下,还是老样子,我一个七尺男儿简直想哭,崩了.....

vue-cli —— 如何局部修改Element样式

vue-cli —— 如何局部修改Element样式

我仍不死心,继续找度娘,终于老天不负有心人,我get到了我的宝贝,把样式单独写在外面就成功了。

vue-cli —— 如何局部修改Element样式

惊喜之余,我发现,这种修改方式存在一个bug,那就是其他页面的样式同时也会被修改成这种样式。我忽的想起,style标签上添加的scoped属性,是表示它的样式作用于当下的模块,很好的实现了样式私有化的目的。如果不加scoped属性,这个样式就具有全局属性。因此,一旦在不加scoped属性的情况下,样式被覆盖,那么整个项目使用到该标签时的样式都会跟着被覆盖。

所以问题又来了,如何让该覆盖样式只在当下组件起作用呢?问谁呢?继续找度娘呗.......(才疏学浅,只会度娘....),找啊找,找啊找,费了好大劲,终于找到了答案。就是简单地用scoped和>>>符号进行穿透。何谓穿透?(引用了第三方组件,需要在组件中局部修改第三方组件的样式,而又不想去除scoped属性造成组件之间的样式污染。这时就要通过特殊的方式,来穿透scoped。)

最后大功告成,如下:

vue-cli —— 如何局部修改Element样式

vue-cli —— 如何局部修改Element样式

注意:

1.这里的  >>> 可以用 /deep/ 替换掉,这里的 /deep/ 操作符是 >>> 的别名,同样也可以正常工作。

2.这里的 !important 不加其实也没毛病,但是因为这是使用第三方库的样式,所以在覆盖样式时最好加上 !important ,这样才能指明优先级。

以上就是vue-cli —— 如何局部修改Element样式的详细内容,更多关于vue 修改Element样式的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
如何用javascript去掉字符串里的所有空格
Feb 08 Javascript
jQuery版仿Path菜单效果
Dec 15 Javascript
CSS鼠标响应事件经过、移动、点击示例介绍
Sep 04 Javascript
javascript中undefined与null的区别
Aug 16 Javascript
跟我学习javascript的arguments对象
Nov 16 Javascript
js实现的星星评分功能函数
Dec 09 Javascript
深入浅析JavaScript字符串操作方法 slice、substr、substring及其IE兼容性
Dec 16 Javascript
详解用node编写自己的cli工具
May 23 Javascript
vue动画打包后失效问题的解决方法
Sep 18 Javascript
JS基于对象的链表实现与使用方法示例
Jan 31 Javascript
layui的数据表格+springmvc实现搜索功能的例子
Sep 28 Javascript
element跨分页操作选择详解
Jun 29 Javascript
微信小程序入门之绘制时钟
Oct 22 #Javascript
微信小程序入门之指南针
Oct 22 #Javascript
微信小程序实现拼图小游戏
Oct 22 #Javascript
Vue select 绑定动态变量的实例讲解
Oct 22 #Javascript
在Vue中使用Select选择器拼接label的操作
Oct 22 #Javascript
JavaScript 中判断变量是否为数字的示例代码
Oct 22 #Javascript
关于vue属性使用和不使用冒号的区别说明
Oct 22 #Javascript
You might like
PHP 采集获取指定网址的内容
2010/01/05 PHP
PHP可变函数的使用详解
2013/06/14 PHP
PHP长连接实现与使用方法详解
2018/02/11 PHP
对于Laravel 5.5核心架构的深入理解
2018/02/22 PHP
php如何利用pecl安装mongodb扩展详解
2019/01/09 PHP
javascript数组组合成字符串的脚本
2021/01/06 Javascript
js中格式化日期时间型数据函数代码
2010/11/08 Javascript
JS date对象的减法处理实现代码
2010/12/28 Javascript
file控件选择上传文件确定后触发的js事件是哪个
2014/03/17 Javascript
JQuery实现样式设置、追加、移除与切换的方法
2015/06/11 Javascript
jQuery实现的手机发送验证码倒计时效果代码分享
2015/08/24 Javascript
jquery实用技巧之输入框提示语句
2016/07/28 Javascript
Node.js读写文件之批量替换图片的实现方法
2016/09/07 Javascript
vue实例中data使用return包裹的方法
2018/08/27 Javascript
vue下拉菜单组件(含搜索)的实现代码
2018/11/25 Javascript
Vue.js中 v-model 指令的修饰符详解
2018/12/03 Javascript
在SSM框架下用laypage和ajax实现分页和数据交互的方法
2019/09/27 Javascript
浅谈Webpack4 Tree Shaking 终极优化指南
2019/11/18 Javascript
Python魔术方法详解
2015/02/14 Python
Python接收Gmail新邮件并发送到gtalk的方法
2015/03/10 Python
Django中反向生成models.py的实例讲解
2018/05/30 Python
django 信号调度机制详解
2019/07/19 Python
python判断一个对象是否可迭代的例子
2019/07/22 Python
pandas统计重复值次数的方法实现
2021/02/20 Python
英国最大的电子零件及配件零售商:Partmaster
2017/04/24 全球购物
Clearly澳大利亚:购买眼镜、太阳镜和隐形眼镜
2018/04/26 全球购物
美国轻奢时尚购物网站:REVOLVE(支持中文)
2020/07/18 全球购物
女大学生自我鉴定
2013/12/09 职场文书
优秀学生干部推荐材料
2014/02/03 职场文书
团日活动总结书
2014/05/08 职场文书
小学安全工作汇报材料
2014/08/19 职场文书
离职证明范本(5篇)
2014/09/19 职场文书
通知格式
2015/04/27 职场文书
2015公司年度工作总结
2015/05/14 职场文书
用Python爬取某乎手机APP数据
2021/06/15 Python
基于Redis的List实现特价商品列表功能
2021/08/30 Redis