一 前言
vue-template-admin是一个非常好用的前端管理框架,但是其菜单栏颜色等设置并不清晰或者去修改等,这篇博客将全面接受如何自定义全面的去修改菜单栏的颜色样式。
二 index.scss文件和sidebar.scss文件
index.scss和sidebar.scss文件共同控制这菜单栏的背景颜色,选中颜色基于选中背景颜色。
index.css包含了全局公共的样式:
:root{
--menuText_1:#bfcbd9;
--menuActiveText_1:#409EFF;
--subMenuActiveText_1:#f4f4f5;
--menuBg_1:#304156;
--menuHover_1:#263445;
--subMenuBg_1:#356DEE;
--subMenuHover_1:#001528;
--boxshaw_1:#3f8ff4;
--versionBg_1:#2C5DA6;
--menuText_2:#fff;
--menuActiveText_2:#3233F9;
--subMenuActiveText_2:#fff;
--menuBg_2:#3a9981;
--menuHover_2:#6DFB63;
--subMenuBg_2:#9FFB9F;
--subMenuHover_2:#CBFBCA;
--boxshaw_2:#9B99F9;
--versionBg_2:#3a9981;
}
:root[theme="t1"]{
--menuText:var(--menuText_1);//主菜单文本栏默认颜色
--menuActiveText:var(--menuActiveText_1);//主菜单栏文本被激活颜色
--subMenuActiveText:var(--subMenuActiveText_1);//子菜单被激活主菜单栏的文本颜色
--menuBg:var(--menuBg_1);//主菜单栏背景颜色
--menuHover:var(--menuHover_1);//主菜单栏悬停时背景颜色
--subMenuBg:var(--subMenuBg_1);//子菜单栏背景颜色
--subMenuHover:var(--subMenuHover_1);//子菜单栏悬停时背景颜色
--menuItemActiveBgColor: var(--menuHover_1);//被选中的菜单栏的背景颜色
--boxshaw:var(--boxshaw_1);
--versionBg:var(--versionBg_1);
}
sidebar.scss文件使用了index.scss里面的定义样式:
我定义的为黑色,效果如图所示;
三,整体index.scss文件
#app {
.main-container {
min-height: 100%;
transition: margin-left .28s;
margin-left: $sideBarWidth;
position: relative;
}
.sidebar-container {
transition: width 0.28s;
width: $sideBarWidth !important;
// background-color: $menuBg;
height: 100%;
position: fixed;
font-size: 0px;
top: 0;
bottom: 0;
left: 0;
z-index: 1001;
overflow: hidden;
box-shadow: 0 0 3px var(--boxshaw);
// reset element-ui css
.horizontal-collapse-transition {
transition: 0s width ease-in-out, 0s padding-left ease-in-out, 0s padding-right ease-in-out;
}
.scrollbar-wrapper {
overflow-x: hidden !important;
}
.el-scrollbar__bar.is-vertical {
right: 0px;
}
.el-scrollbar {
height: 100%;
}
&.has-logo {
.el-scrollbar {
height: calc(100% - 50px);
}
}
.is-horizontal {
display: none;
}
a {
display: inline-block;
width: 100%;
overflow: hidden;
}
.svg-icon {
margin-right: 16px;
}
.sub-el-icon {
margin-right: 12px;
margin-left: -2px;
}
.el-menu {
border: none;
height: 100%;
width: 100% !important;
}
// menu hover
.submenu-title-noDropdown,
.el-submenu__title {
&:hover {
background-color: var(--menuHover) !important;
}
}
//选中时,主菜单颜色
.is-active>.el-submenu__title {
color: var(--subMenuActiveText) !important;//
// background-color: var(--menuItemActiveBgColor) !important;
}
//选中菜单栏的背景颜色
.el-menu .el-menu-item.is-active {
background: var(--menuItemActiveBgColor)!important;
}
& .nest-menu .el-submenu>.el-submenu__title,
& .el-submenu .el-menu-item {
min-width: $sideBarWidth !important;
background-color: var(--subMenuBg) !important;
// color: var(--menuActiveText)!important;
&:hover {
background-color: var(--subMenuHover) !important;
}
}
}
.hideSidebar {
.sidebar-container {
width: 54px !important;
}
.main-container {
margin-left: 54px;
}
.submenu-title-noDropdown {
padding: 0 !important;
position: relative;
.el-tooltip {
padding: 0 !important;
.svg-icon {
margin-left: 20px;
}
.sub-el-icon {
margin-left: 19px;
}
}
}
.el-submenu {
overflow: hidden;
&>.el-submenu__title {
padding: 0 !important;
.svg-icon {
margin-left: 20px;
}
.sub-el-icon {
margin-left: 19px;
}
.el-submenu__icon-arrow {
display: none;
}
}
}
.el-menu--collapse {
.el-submenu {
&>.el-submenu__title {
&>span {
height: 0;
width: 0;
overflow: hidden;
visibility: hidden;
display: inline-block;
}
}
}
}
}
.el-menu--collapse .el-menu .el-submenu {
min-width: $sideBarWidth !important;
}
// mobile responsive
.mobile {
.main-container {
margin-left: 0px;
}
.sidebar-container {
transition: transform .28s;
width: $sideBarWidth !important;
}
&.hideSidebar {
.sidebar-container {
pointer-events: none;
transition-duration: 0.3s;
transform: translate3d(-$sideBarWidth, 0, 0);
}
}
}
.withoutAnimation {
.main-container,
.sidebar-container {
transition: none;
}
}
}
// when menu collapsed
.el-menu--vertical {
&>.el-menu {
.svg-icon {
margin-right: 16px;
}
.sub-el-icon {
margin-right: 12px;
margin-left: -2px;
}
}
.nest-menu .el-submenu>.el-submenu__title,
.el-menu-item {
&:hover {
// you can use $subMenuHover
background-color: var(--menuHover) !important;
}
}
// the scroll bar appears when the subMenu is too long
>.el-menu--popup {
max-height: 100vh;
overflow-y: auto;
&::-webkit-scrollbar-track-piece {
background: #d3dce6;
}
&::-webkit-scrollbar {
width: 6px;
}
&::-webkit-scrollbar-thumb {
background: #99a9bf;
border-radius: 20px;
}
}
}
sidebar.scss文件中使用var(--xxx)的就是在使用index.scss中自定义的样式颜色,大家可以根据需要进行颜色调整。