Element-Plus 面包屑当前项样式以及处理最后一个元素

需求:

通过 面包屑el-breadcrumb组件 实现路由菜单的二次显示,需要当前显示的页面与对应的面包屑菜单联动高亮。

由于该组件给最后一个元素在伪类last-child上设置了样式,所以得对其样式做出调整。

html 复制代码
         <el-breadcrumb separator="/">
            <!-- 首页始终显示 -->
            <el-breadcrumb-item :to="{ path: '/home' }">
              <el-icon><House /></el-icon>
              首页
            </el-breadcrumb-item>

            <!-- 动态面包屑项 -->
            <el-breadcrumb-item
              v-for="item in breadcrumbs"
              :key="item.path"
              :to="{ path: item.path }"
              :class="{ 'current-breadcrumb': item.path === route.path }"
              @click="handleBreadcrumbClick(item)"
            >
              <!-- 菜单图标 -->
              <!-- <el-icon><component :is="route.meta.icon || 'Document'" /></el-icon> -->
              {{ item.title }}
              <el-icon class="breadcrumb-close" @click="removeBreadcrumb(item, $event)">
                <Close />
              </el-icon>
              <!-- 只有非当前页面才显示删除按钮 -->
              <!-- <el-icon
                v-if="item.path !== route.path"
                class="breadcrumb-close"
                @click="removeBreadcrumb(item, $event)"
              >
                <Close />
              </el-icon> -->
            </el-breadcrumb-item>
          </el-breadcrumb>

当前项单独设置类样式:

复制代码
 :class="{ 'current-breadcrumb': item.path === route.path }"
css 复制代码
$breadcrumb-item-color: #409eff;

// 面包屑样式
::v-deep .el-breadcrumb {
  .el-breadcrumb__inner.is-link:hover {
    color: $breadcrumb-item-color;
  }
  /* 自定义当前项样式 */
  .current-breadcrumb .el-breadcrumb__inner {
    color: $breadcrumb-item-color;
    font-weight: bold;
  }

  // 最后一个元素
  .el-breadcrumb__item:last-child .el-breadcrumb__inner {
    color: inherit;
    cursor: pointer;
    font-weight: bold;
    &:hover {
      color: $breadcrumb-item-color;
    }
  }

  .current-breadcrumb:last-child .el-breadcrumb__inner {
    color: $breadcrumb-item-color;
  }
}
相关推荐
Liu.77443 分钟前
vue开发h5项目
vue.js
pas1361 小时前
42-mini-vue 实现 transform 功能
前端·javascript·vue.js
柒.梧.2 小时前
从零搭建SpringBoot+Vue+Netty+WebSocket+WebRTC视频聊天系统
vue.js·spring boot·websocket
毕设源码-钟学长2 小时前
【开题答辩全过程】以 基于node.js vue的点餐系统的设计与实现为例,包含答辩的问题和答案
前端·vue.js·node.js
小白路过2 小时前
记录vue-cli-service serve启动本地服务卡住问题
前端·javascript·vue.js
梵得儿SHI2 小时前
Vue 高级特性:渲染函数与 JSX 精讲(h 函数语法、JSX 在 Vue 中的应用)
前端·javascript·vue.js·jsx·模板语法·渲染函数·底层视图生成机制
David凉宸2 小时前
Vue 3 项目的性能优化策略:从原理到实践(页面展示)
javascript·vue.js·性能优化
Byron07073 小时前
基于 Vue 的微前端架构落地实战:从 0 到 1 搭建企业级多应用体系
前端·vue.js·架构
芭拉拉小魔仙3 小时前
Vue 3 组合式 API 详解:告别 Mixins,拥抱函数式编程
前端·javascript·vue.js
qq_12498707533 小时前
基于Javaweb的《战舰世界》游戏百科信息系统(源码+论文+部署+安装)
java·vue.js·人工智能·spring boot·游戏·毕业设计·计算机毕业设计