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 添加节点的几种方法介绍
Sep 04 Javascript
浅析jquery unbind()方法移除元素绑定的事件
May 24 Javascript
浅谈在js传递参数中含加号(+)的处理方式
Oct 11 Javascript
js实现打地鼠小游戏
Feb 13 Javascript
jQuery实现的页面详情展开收起功能示例
Jun 11 jQuery
jQuery AJAX 方法success()后台传来的4种数据详解
Aug 08 jQuery
vue-cli3.0 脚手架搭建项目的过程详解
Oct 19 Javascript
webpack打包非模块化js的方法
Oct 24 Javascript
vue3修改link标签默认icon无效问题详解
Oct 09 Javascript
countUp.js实现数字动态变化效果
Oct 17 Javascript
js实现鼠标滑动到某个div禁止滚动
Sep 17 Javascript
antd vue table跨行合并单元格,并且自定义内容实例
Oct 28 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
libmysql.dll与php.ini是否真的要拷贝到c:\windows目录下呢
2010/03/15 PHP
CI框架网页缓存简单用法分析
2018/12/26 PHP
javascript URL锚点取值方法
2009/02/25 Javascript
js实现单一html页面两套css切换代码
2013/04/11 Javascript
利用百度地图JSAPI生成h7n9禽流感分布图实现代码
2013/04/15 Javascript
用C/C++来实现 Node.js 的模块(一)
2014/09/24 Javascript
Jquery 实现弹出层插件
2015/01/28 Javascript
JS动态日期时间的获取方法
2015/09/28 Javascript
jQuery表格插件datatables用法详解
2020/11/23 Javascript
Angularjs中如何使用filterFilter函数过滤
2016/02/06 Javascript
easyui-datagrid开发实践(总结)
2017/08/02 Javascript
WebSocket的通信过程与实现方法详解
2018/04/29 Javascript
nodejs中用npm初始化来创建package.json的实例讲解
2018/10/10 NodeJs
js计时事件实现圆形时钟
2020/03/25 Javascript
原生js实现购物车
2020/09/23 Javascript
Python多线程同步Lock、RLock、Semaphore、Event实例
2014/11/21 Python
Python Web框架Flask中使用七牛云存储实例
2015/02/08 Python
浅谈python字典多键值及重复键值的使用
2016/11/04 Python
Python 限制线程的最大数量的方法(Semaphore)
2019/02/22 Python
Python列表对象实现原理详解
2019/07/01 Python
python使用正则来处理各种匹配问题
2019/12/22 Python
将数据集制作成VOC数据集格式的实例
2020/02/17 Python
Python爬虫如何破解JS加密的Cookie
2020/11/19 Python
利用css3-animation实现逐帧动画效果
2016/03/10 HTML / CSS
使用HTML5做个画图板的方法介绍
2013/05/03 HTML / CSS
详解HTML5中ol标签的用法
2015/09/08 HTML / CSS
美国马匹用品和骑马配件购物网站:Horse.com
2018/01/08 全球购物
中东奢侈品购物网站:Ounass
2020/09/02 全球购物
简述安装Slackware Linux系统的过程
2012/01/12 面试题
在对linux系统分区进行格式化时需要对磁盘簇(或i节点密度)的大小进行选择,请说明选择的原则
2012/11/24 面试题
教师个人自我剖析材料
2014/09/29 职场文书
教师党员批评与自我批评发言稿
2014/10/15 职场文书
教育见习报告范文
2014/11/03 职场文书
2014年检验科工作总结
2014/11/22 职场文书
分享Python异步爬取知乎热榜
2022/04/12 Python
Spring中bean集合注入的方法详解
2022/07/07 Java/Android