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;
}
相关推荐
_OP_CHEN7 分钟前
【前端开发之CSS】(三)CSS 常用元素属性宝典(上):从字体到文本,手把手教你打造高颜值网页!
前端·css·html·网页开发·文本属性·字体属性·页面美化
你脸上有BUG1 小时前
【工程化】记给ant-design-vue打补丁的示例
前端·javascript·vue.js·补丁·ant-design-vue
你这个代码我看不懂1 小时前
Vue子父组件.sync
javascript·vue.js·ecmascript
灰灰勇闯IT2 小时前
Flutter for OpenHarmony:布局组件实战指南
前端·javascript·flutter
⑩-2 小时前
Vue框架学习
前端·vue.js·学习
a程序小傲2 小时前
京东Java面试被问:基于Gossip协议的最终一致性实现和收敛时间
java·开发语言·前端·数据库·python·面试·状态模式
小二·2 小时前
Python Web 开发进阶实战:AI 原生应用商店 —— 在 Flask + Vue 中构建模型即服务(MaaS)与智能体分发平台
前端·人工智能·python
Devlive 开源社区2 小时前
技术日报|推理RAG文档索引PageIndex登顶日增1374星,React视频工具Remotion二连冠进前二
前端·react.js·前端框架
xkxnq2 小时前
第三阶段:Vue 路由与状态管理(第 45 天)(路由与状态管理实战:开发一个带登录权限的单页应用)
前端·javascript·vue.js
Irene19912 小时前
Vue 3 中的具名插槽仍然完全支持,Vue 2 的旧语法 Vue 3 中已废弃
vue.js·slot