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 相关文章推荐
基于JQuery实现异步刷新的代码(转载)
Mar 29 Javascript
jQuery调用WebService的实现代码
Jun 19 Javascript
javascript实现yield的方法
Nov 06 Javascript
jQuery中position()方法用法实例
Jan 16 Javascript
基于jQuery实现自动轮播旋转木马特效
Nov 02 Javascript
基于jQuery倒计时插件实现团购秒杀效果
May 13 Javascript
layer实现弹窗提交信息
Dec 12 Javascript
文件上传的几个示例分享【推荐】
Dec 16 Javascript
jQuery日程管理控件glDatePicker用法详解
Mar 29 jQuery
使用jQuery给Table动态增加行、清空table的方法
Sep 05 jQuery
微信小程序学习笔记之表单提交与PHP后台数据交互处理图文详解
Mar 28 Javascript
jQuery设置下拉框显示与隐藏效果的方法分析
Sep 15 jQuery
微信小程序入门之绘制时钟
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 采集书并合成txt格式的实现代码
2009/03/01 PHP
在php和MySql中计算时间差的方法
2011/04/22 PHP
有关phpmailer的详细介绍及使用方法
2013/01/28 PHP
ThinkPHP框架设计及扩展详解
2014/11/25 PHP
PHP实现支付宝即时到账功能
2016/12/21 PHP
PHP根据key删除数组中指定的元素
2019/02/28 PHP
PHP实现数组向任意位置插入,删除,替换数据操作示例
2019/04/05 PHP
js 对联广告、漂浮广告封装类(IE,FF,Opera,Safari,Chrome
2009/11/26 Javascript
关于onScroll事件在IE6下每次滚动触发三次bug说明
2011/09/21 Javascript
js读取json的两种常用方法示例介绍
2014/10/19 Javascript
jQuery动态添加与删除tr行实例代码
2016/10/18 Javascript
EasyUI折叠表格层次显示detailview详解及实例
2016/12/28 Javascript
详解angularJS动态生成的页面中ng-click无效解决办法
2017/06/19 Javascript
node通过express搭建自己的服务器
2017/09/30 Javascript
Express结合Webpack的全栈自动刷新
2019/05/23 Javascript
JS+HTML实现自定义上传图片按钮并显示图片功能的方法分析
2020/02/12 Javascript
uni-app从安装到卸载的入门教程
2020/05/15 Javascript
压缩包密码破解示例分享(类似典破解)
2014/01/17 Python
Python实现的井字棋(Tic Tac Toe)游戏示例
2018/01/31 Python
python 实现交换两个列表元素的位置示例
2019/06/26 Python
django的auth认证,authenticate和装饰器功能详解
2019/07/25 Python
解决pytorch-yolov3 train 报错的问题
2020/02/18 Python
HTML5触摸事件(touchstart、touchmove和touchend)的实现
2020/05/08 HTML / CSS
网上常见的一份Linux面试题(多项选择部分)
2014/09/09 面试题
优秀团员个人的自我评价
2013/10/02 职场文书
毕业生动漫设计求职信
2013/10/11 职场文书
应聘美工求职信
2013/11/07 职场文书
两年的个人工作自我评价
2014/01/10 职场文书
初婚初育证明
2014/01/14 职场文书
文明餐桌活动方案
2014/02/11 职场文书
集体生日活动方案
2014/08/18 职场文书
住房抵押登记委托书
2014/09/27 职场文书
2015年119消防宣传日活动总结
2015/03/24 职场文书
承兑汇票延期证明
2015/06/23 职场文书
给学校的建议书400字
2015/09/14 职场文书
MySQL数据库简介与基本操作
2022/05/30 MySQL