【Vue.js + Element UI】实现左侧导航栏制作

【Vue.js + Element UI】实现左侧导航栏制作

在这里插入图片描述

利用Element UI进行页面搭建

/components/Menu.vue

<template>
  <div class="aside">
    <!-- 导航菜单组件
      el-menu: 容器组件
      @open 监听下拉打开
      @close 监听下拉菜单打开
      default-active string 默认选中的菜单项的index的值
      text-color: 文本的颜色
      active-text-color: 菜单被选中时的文本颜色
      router: 是否使用vue-router的模式进行跳转,启用该模式激活导航时以Index作为
      参数进行路由跳转
      default-active 设置为当前路由的path
     -->
    <el-menu
      router
      :default-active="$route.path"
      class="el-menu-vertical-demo"
      background-color="#3d5f81"
      text-color="#fff"
      active-text-color="#ffd04b"
    >
      <!-- 没有下级菜单的菜单项 -->
      <el-menu-item index="/statistics">
        <i class="el-icon-menu"></i>
        <span slot="title">首页</span>
      </el-menu-item>
      <!-- 有下级菜单的菜单项 -->
      <el-submenu index="1">
        <template slot="title">
          <i class="el-icon-s-tools"></i>
          <span>系统管理</span>
        </template>
        <!-- 一组菜单项 -->
        <el-menu-item-group>
          <el-menu-item index="/menu">菜单管理</el-menu-item>
          <el-menu-item index="/role">角色管理</el-menu-item>
          <el-menu-item index="/admin">管理员管理</el-menu-item>
        </el-menu-item-group>
      </el-submenu>

       <el-submenu index="2">
        <template slot="title">
          <i class="el-icon-s-goods"></i>
          <span>商城管理</span>
        </template>
        <!-- 一组菜单项 -->
        <el-menu-item-group>
          <el-menu-item index="/category">商品分类</el-menu-item>
          <el-menu-item index="/specs">商品规格</el-menu-item>
          <el-menu-item index="/goods">商品管理</el-menu-item>
          <el-menu-item index="/seckill">秒杀活动</el-menu-item>
          <el-menu-item index="/banner">轮播图管理</el-menu-item>
        </el-menu-item-group>
      </el-submenu>
    </el-menu>
  </div>
</template>

<script>
export default {}
</script>

<style scoped>
.aside {
  background: #3d5f81;
  height: 100%;
}
.el-menu {
  border-right: none;
}
</style>

配置路由

/src/router/routes.js

const routes = [
  {
    path: '/',
    // 重定向
    redirect: '/statistics',
    name: 'Index',
    component: () => import('@/pages/main/Index'),
    children: [
      {
        path: 'statistics',
        name: 'statistics',
        component: () => import('@/pages/statistics/Index'),
        meta: {
          title: '图表统计'
        }
      },
      {
        path: 'menu',
        name: 'menu',
        component: () => import('@/pages/menu/Index'),
        meta: {
          title: '菜单管理'
        }
      },
      {
        path: 'role',
        name: 'role',
        component: () => import('@/pages/role/Index'),
        meta: {
          title: '角色管理'
        }
      },
      {
        path: 'admin',
        name: 'admin',
        component: () => import('@/pages/admin/Index'),
        meta: {
          title: '管理员管理'
        }
      },
      {
        path: 'category',
        name: 'category',
        component: () => import('@/pages/category/Index'),
        meta: {
          title: '商品分类'
        }
      },
      {
        path: 'specs',
        name: 'specs',
        component: () => import('@/pages/specs/Index'),
        meta: {
          title: '商品规格'
        }
      },
      {
        path: 'goods',
        name: 'goods',
        component: () => import('@/pages/goods/Index'),
        meta: {
          title: '商品管理'
        }
      },
      {
        path: 'seckill',
        name: 'seckill',
        component: () => import('@/pages/seckill/Index'),
        meta: {
          title: '秒杀活动'
        }
      },
      {
        path: 'banner',
        name: 'banner',
        component: () => import('@/pages/banner/Index'),
        meta: {
          title: '轮播图'
        }
      }
    ]
  },
  {
    path: '/login',
    name: 'login',
    component: () => import('@/pages/login/Index'),
    meta: {
      title: '登录'
    }
  }
]

export default routes

  • 3
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值