VUE+ElementUI更改导航菜单选中背景颜色

简介: VUE+ElementUI更改导航菜单选中背景颜色

VUE+ElementUI更改导航菜单选中背景颜色

主要是设置 .el-menu-item.is-active 选择器的样式属性
1565748938384

官方文档中提供background-color、text-color、active-text-color三种属性
1565749733834

仅提供了激活菜单文字颜色,并没有提供激活菜单的其他参数

<el-menu default-active="0" class="el-menu-vertical-demo"
          @open="handleOpen"
          @close="handleClose"
          :collapse="collapsed"
          background-color="#fff"
          text-color="#777F8F"
          active-text-color="#6681FA">

1565751106952
使用提供的属性,并设置 .el-menu-item.is-active 样式
可以看到我们使用了提供的参数之后,是JS直接更改了HTML样式,由于权重较低css样式失效了.el-menu-item.is-active,菜单背景色background-color 覆盖 激活菜单背景色 background-color
使用 !important 优先级最大 可以实现

        .el-menu-item.is-active {
          color: #6681FA;
          background-color: #EAEEFF!important;
        }

以上方法不推荐使用,两点原因,第一点js和css混合使用增加耦合度,第二点使用 优先级最大 的方法覆盖原有框架增加了后期维护难度。

以下方法解决
推荐不使用官方提供的属性,直接使用css即可,注意书写顺序

        .el-menu-item {
          color: #777F8F;
        }
        .el-menu-item.is-active {
          color: #6681FA;
          background-color: #EAEEFF;
        }

1565749208260

css样式直接使用类选择器解决耦合或继承性问题,类选择器的权重为1,增加自定义 class 可轻松解决,如果有js改变样式的情况,可以增加 js 钩子方便维护也适用复杂场景,例:.js-show

目录
相关文章
|
1天前
|
JavaScript 前端开发
【vue】iview如何把input输入框和点击输入框之后的边框去掉
【vue】iview如何把input输入框和点击输入框之后的边框去掉
7 0
|
1天前
|
JavaScript
【vue实战】父子组件互相传值
【vue实战】父子组件互相传值
6 1
|
1天前
|
JavaScript
vue2_引入Ant design vue
vue2_引入Ant design vue
6 0
|
1天前
|
JavaScript
vue知识点
vue知识点
10 4
|
2天前
|
存储 JavaScript 前端开发
【Vue】绝了!这生命周期流程真...
【Vue】绝了!这生命周期流程真...
|
2天前
|
JavaScript 索引
【vue】框架搭建
【vue】框架搭建
7 1
|
2天前
|
JavaScript 前端开发 容器
< 每日小技巧: 基于Vue状态的过渡动画 - Transition 和 TransitionGroup>
Vue 的 `Transition` 和 `TransitionGroup` 是用于状态变化过渡和动画的组件。`Transition` 适用于单一元素或组件的进入和离开动画,而 `TransitionGroup` 用于 v-for 列表元素的增删改动画,支持 CSS 过渡和 JS 钩子。
< 每日小技巧: 基于Vue状态的过渡动画 - Transition 和 TransitionGroup>
|
2天前
|
JavaScript
【vue】setInterval的嵌套实例
【vue】setInterval的嵌套实例
8 1