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 词法作用域和闭包分析说明
Aug 12 Javascript
读jQuery之四(优雅的迭代)
Jun 20 Javascript
怎么判断js脚本加载完成
Feb 28 Javascript
Jquery实现兼容各大浏览器的Enter回车切换输入焦点的方法
Sep 01 Javascript
js表单中选择框值的获取及表单的序列化
Dec 17 Javascript
使用JavaScript为Kindeditor自定义按钮增加Audio标签
Mar 18 Javascript
纯js实现隔行变色效果
Nov 29 Javascript
关于vuejs中v-if和v-show的区别及v-show不起作用问题
Mar 26 Javascript
jQuery模拟12306城市选择框功能简单实现方法示例
Aug 13 jQuery
vue3.0 CLI - 2.1 -  component 组件入门教程
Sep 14 Javascript
webstorm中配置Eslint的两种方式及差异比较详解
Oct 19 Javascript
对layer弹出框中icon数字参数的说明介绍
Sep 04 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 fsockopen伪造post与get方法的详解
2013/06/14 PHP
修改php.ini以达到屏蔽错误信息并记录日志
2013/06/16 PHP
Yii使用find findAll查找出指定字段的实现方法
2014/09/05 PHP
php array_udiff_assoc 计算两个数组的差集实例
2016/11/12 PHP
ajax+php实现无刷新验证手机号的实例
2017/12/22 PHP
纯Javascript实现Windows 8 Metro风格实现
2013/10/15 Javascript
js实现的捐赠管理完整实例
2015/01/20 Javascript
jquery动态添加删除(tr/td)
2015/02/09 Javascript
javascript中offset、client、scroll的属性总结
2015/08/13 Javascript
JavaScript字符串对象(string)基本用法示例
2017/01/18 Javascript
解决JS内存泄露之js对象和dom对象互相引用问题
2017/06/25 Javascript
javascript基本常用排序算法解析
2017/09/27 Javascript
angular项目中bootstrap-datetimepicker时间插件的使用示例
2018/03/15 Javascript
webpack4.x下babel的安装、配置及使用详解
2019/03/07 Javascript
为nuxt项目写一个面包屑cli工具实现自动生成页面与面包屑配置
2019/09/29 Javascript
webpack3升级到webpack4遇到问题总结
2019/09/30 Javascript
vue更改数组中的值实例代码详解
2020/02/07 Javascript
JavaScript图像放大镜效果实现方法详解
2020/06/28 Javascript
vue v-for 点击当前行,获取当前行数据及event当前事件对象的操作
2020/09/10 Javascript
JavaScript 如何计算文本的行数的实现
2020/09/14 Javascript
[05:31]DOTA2英雄梦之声_第04期_光之守卫
2014/06/23 DOTA
[02:45]2016年中国刀塔全程回顾,完美“圣”典即将上演
2016/12/15 DOTA
Python中asyncore异步模块的用法及实现httpclient的实例
2016/06/28 Python
关于python写入文件自动换行的问题
2018/06/23 Python
python and or用法详解
2019/06/26 Python
详解Python3 pickle模块用法
2019/09/16 Python
详解如何在PyCharm控制台中输出彩色文字和背景
2020/08/17 Python
Scrapy基于scrapy_redis实现分布式爬虫部署的示例
2020/09/29 Python
CSS3按钮鼠标悬浮实现光圈效果源码
2016/09/11 HTML / CSS
美国最大的珠宝商之一:Littman Jewelers
2016/11/13 全球购物
公司管理制度范本
2015/08/03 职场文书
文明礼仪主题班会
2015/08/13 职场文书
自定义函数实现单词排序并运用于PostgreSQL(实现代码)
2021/04/22 PostgreSQL
python库sklearn常用操作
2021/08/23 Python
baselines示例程序train_cartpole.py的ImportError
2022/05/20 Python
python数据分析之单因素分析线性拟合及地理编码
2022/06/25 Python