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代码实例
Jun 15 Javascript
jQuery获取注册信息并提示实现代码
Apr 21 Javascript
给超链接添加特效鼠标移动展示提示信息且随鼠标移动
Oct 17 Javascript
javascript中offset、client、scroll的属性总结
Aug 13 Javascript
[原创]Javascript 实现广告后加载 可加载百度谷歌联盟广告
May 11 Javascript
JavaScript实现页面无操作倒计时退出
Oct 22 Javascript
JS无缝滚动效果实现方法分析
Dec 21 Javascript
JSON创建键值对(key是中文或者数字)方式详解
Aug 24 Javascript
Node层模拟实现multipart表单的文件上传示例
Jan 02 Javascript
JavaScrip数组去重操作实例小结
Jun 20 Javascript
vue-router的钩子函数用法实例分析
Oct 26 Javascript
Handtrack.js库实现实时监测手部运动(推荐)
Feb 08 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 current函数获取未知字符键名数组第一个元素的值
2013/06/24 PHP
php增删改查示例自己写的demo
2013/09/04 PHP
PHP获取MAC地址的具体实例
2013/12/13 PHP
Laravel框架数据库CURD操作、连贯操作总结
2014/09/03 PHP
PHP使用Curl实现模拟登录及抓取数据功能示例
2018/04/27 PHP
使用JS操作页面表格,元素的一些技巧
2007/02/02 Javascript
yepnope.js 异步加载资源文件
2011/09/08 Javascript
js实现字符串的16进制编码不加密
2014/04/25 Javascript
jquery 表格排序、实时搜索表格内容(附图)
2014/05/19 Javascript
什么是cookie?js手动创建和存储cookie
2014/05/27 Javascript
jqueryUI里拖拽排序示例分析
2015/02/26 Javascript
基于jquery实现省市联动特效
2015/12/17 Javascript
聊一聊JS中this的指向问题
2016/06/17 Javascript
基于Vuejs框架实现翻页组件
2020/06/29 Javascript
vue.js全局API之nextTick全面解析
2017/07/07 Javascript
NodeJS安装图文教程
2018/04/19 NodeJs
浅谈React 服务器端渲染的使用
2018/05/08 Javascript
vue2.0 实现导航守卫的具体用法(路由守卫)
2018/05/17 Javascript
详解如何用VUE写一个多用模态框组件模版
2018/09/27 Javascript
Vue拖拽组件列表实现动态页面配置功能
2019/06/17 Javascript
vue-cli创建的项目中的gitHooks原理解析
2020/02/14 Javascript
Vue+ElementUI 中级联选择器Bug问题的解决
2020/07/31 Javascript
[01:05:59]Mineski vs Secret 2019国际邀请赛淘汰赛 败者组 BO3 第二场 8.22
2019/09/05 DOTA
Python编程中的反模式实例分析
2014/12/08 Python
用Python制作在地图上模拟瘟疫扩散的Gif图
2015/03/31 Python
python使用SQLAlchemy操作MySQL
2020/01/02 Python
Spring http服务远程调用实现过程解析
2020/06/11 Python
python给list排序的简单方法
2020/12/10 Python
python des,aes,rsa加解密的实现
2021/01/16 Python
HTML5的Video标签有部分MP4无法播放的问题解析(多图)
2017/08/18 HTML / CSS
No7 Beauty美国官网:英国国民护肤品牌
2019/10/31 全球购物
Timberland法国官网:购买靴子、鞋子、衣服、夹克和配饰
2019/11/30 全球购物
经典优秀个人求职自荐信格式
2013/09/25 职场文书
大学生写自荐信的技巧
2014/01/08 职场文书
安全口号大全
2014/06/21 职场文书
大学开学典礼新闻稿
2015/07/17 职场文书