elementplus菜单组件的那些事

在使用 elementplus 的菜单组件时,我发现有很多东西是官方没有提到但是需要注意的点

  1. 菜单组件右侧会有一个边框

设置css

css 复制代码
.el-menu {
  border: 0 !important;
}
  1. 使用其他的 icon

文字内容一定要写在 这个名字为 title 的插槽中

html 复制代码
<el-menu-item
      
        v-for="item in navList"
        :key="item"
        :index="
         item.path
        "
      >
        <span
          style="margin-right: 20px; font-weight: bold"
          :class="item.icon"
        ></span>//这个地方我使用的是 阿里巴巴图标库里面的图表
        <template #title>
         {{ item.text }}//文字要在这里面
        </template>
      </el-menu-item>
  1. 刷新不能回到对应的 活动样式失效

我这边使用的是 :class 加 设置 :default-active

先是在 el-menu-item 中指定了 选中时的样式

html 复制代码
<el-menu-item
      :class="{subActive:getCurrentPath()==item.path}"//这行代码待会会解释
        v-for="item in navList"
        :key="item"
        :index="
          item.path
        "
      >
        <span
          style="margin-right: 20px; font-weight: bold"
          :class="item.icon"
        ></span>
        <template #title>
         {{ item.text }}
        </template>
      </el-menu-item>

通过 getCurrentPath 这个函数获取到 当前的路径 ,并且 判断是否和当前的路径符合,来控制样式是否显示

我这边的 getCurrentPath 这个函数里面 是因为 前面前缀是一样的,我只需要判断后面是否相等就行,之所以会这样写 是因为很多时候 我们左侧的路由 因为右边的内容页,再细分,但是呢,它是同属于一个大的路由的,它们会有一个公共的前缀部分,只需要保证公共前缀部分相等就行

javascript 复制代码
const getCurrentPath = () => {
  let currentPath = route.path.split("/");

  // console.log(currentPath);

  for (let i = 0; i < navList.length; i++) {
    let path = navList[i].path.split("/");

    if (flag === 0) {
      if (path[2] == currentPath[2]) {
        return navList[i].path;
      }
    }
    else{
      if (path[1] === currentPath[3]) {
        
        return navList[i].path;
      }
    }
  }
};

一般情况应该是这样,插一嘴,route 指的是 这个

javascript 复制代码
import { useRoute } from "vue-router";

const route = useRoute();
javascript 复制代码
const getCurrentPath = () => {
  
  for (let i = 0; i < navList.length; i++) {
    if(navList[i].path===route.path) return navlist[i].path
    //其实就是判断 菜单的路由是否对的上当前路径
  }
};

然后 在 el-menu 中 需要设置 router 模式,也就是需要加上这个,设置默认路由 是 getCurrentPath()就好(一定需要匹配的上 :index 里面的内容)

javascript 复制代码
<el-menu
      class="el-menu-vertical-demo"
      :collapse="isCollapse"
      router
      :default-active="getCurrentPath()"
    >

</el-menu>
  1. 修改高度等

element-plus 中很多样式都是设置了一个固定的值来设定css的一些参数,当我们需要修改这些的时候,我们发现使用 css 覆盖的效果微乎其微,其实我们可以自己修改这些值

很多都可以去检查里面找到,然后进行修改

css 复制代码
:root {
  --el-menu-item-height: 80px;//这个是每个子菜单高度
  --el-menu-base-level-padding: 40px;//padding值
  --el-text-color-primary: #8a8989;//文字颜色
}
相关推荐
Z_Wonderful3 小时前
在 Next.js 中,使用 [id] 或 public 作为文件夹或文件名是两种完全不同的概念,分别对应 动态路由 和 静态资源托管
javascript·网络·chrome
咬人喵喵3 小时前
E2.COOL 平台深度解析:从特效分类到实战操作指南
前端·编辑器·svg
RisunJan4 小时前
Linux命令-named-checkzone
linux·前端
小陈工4 小时前
Python Web开发入门(十):数据库迁移与版本管理——让数据库变更可控可回滚
前端·数据库·人工智能·python·sql·云原生·架构
吹晚风吧4 小时前
解决vite打包,base配置前缀,nginx的dist包找不到资源
服务器·前端·nginx
weixin199701080164 小时前
《施耐德商品详情页前端性能优化实战》
前端·性能优化
不想上班只想要钱5 小时前
模板里 item.xxx 报错 ,报 item的类型为未知
前端·vue
妖萌妹儿5 小时前
postman怎么做参数化批量测试,测试不同输入组合
开发语言·javascript·postman
阿琳a_5 小时前
在github上部署个人的vitepress文档网站
前端·vue.js·github·网站搭建·cesium
酉鬼女又兒5 小时前
零基础快速入门前端ES6 核心特性详解与蓝桥杯 Web 考点实践(可用于备赛蓝桥杯Web应用开发)
开发语言·前端·职场和发展·蓝桥杯·es6·css3·html5