vue项目中,修改elementui一些复杂控件样式

1.前言

在vue项目中,我们为了快速开发,会用到elementui。但很多时候,elementui的样式不满足于我们项目的样式需求。这时候我们需要修改原生elementui的样式。

2.简单控件的样式修改

对于elementui中一些简单的控件,如按钮之类的,没有复杂的交互空间,可以直接打开 f12调试页面,找到该dom元素的class名称,在vue页面下重写覆盖该样式即可。

如果没有生效,也可以通过在改class前,加上父级的class,提高该样式的优先级。

如图,直接在页面上修改css覆盖

复制代码
.el-button--default{
   background: "#ffcc00";
}

或者:

复制代码
.parentClass .el-button--default{
   background: "#ffcc00";
}

注意parentClass 是包住按钮的父标签的class,如果引入了sass则写法为

复制代码
.parentClass {
	.el-button--default{
  		 background: "#ffcc00";
	}
}

3.复杂控件样式的修改

当我们遇到复杂的控件时,以上方法我们会发现我们设置的样式并不能生效,比如颜色选择器控件:

我们之间用上面的方式覆盖样式el-color-picker__trigger并不能生效。

这时候我们需要使用v-deep深度选择器,如下写法才可以覆盖成功(我这里工程是引入了sass的,深度选择器写法如下):

复制代码
::v-deep .el-color-picker__trigger {
  display: inline-block;
  box-sizing: border-box;
  height: 144px;
  width: 193px;
  /* padding: 4px; */
  /* border: 1px solid #e6e6e6; */
  border-radius: 6px;
  font-size: 0;
  position: relative;
  cursor: pointer;
}
相关推荐
iccb101316 分钟前
5年,一个程序员是如何把私有化在线客服系统做到第一名的
前端·后端·github
假如让我当三天老蒯22 分钟前
回归基本功:Map/Set 与 WeakMap/WeakSet 的区别
前端·面试
IT乐手38 分钟前
48队都装不下你|国足第24次让全世界失望
前端
SoaringHeart2 小时前
Flutter最佳实践:IM聊天文字链接自动识别跳转
前端·flutter
掘金一周2 小时前
企业中要做智能体,最佳的方案是什么? | 沸点周刊 6.18
前端·人工智能·ai编程
Darling噜啦啦2 小时前
CSS 3D 变换与 Flex 布局实战:从零打造旋转立方体
前端·css
秃头网友小李3 小时前
前端难点:keep-alive 缓存什么?RouterView 的 key 为什么要带 scopeId?
前端·vue.js
鱼人3 小时前
CSS 变量:一个变量救你一百次复制粘贴
前端
长大19883 小时前
CSS 到底是什么?和 HTML 的区别一次讲清楚
前端
禅思院3 小时前
路由性能优化终极指南:从懒加载漏洞到边缘渲染的架构跃迁
前端·架构·前端框架