基于vue-element-admin基础模板实现侧边栏菜单动态渲染

本文介绍了如何在Vue.js应用中实现动态路由、自定义侧边栏和Vuex状态管理。通过示例代码展示了如何设置路由、根据条件展示侧边栏项,并利用Vuex存储和同步应用程序的状态,特别是针对顶部导航菜单的切换。同时,还展示了在不同页面间如何切换并保持用户选择的导航状态。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

下载:

GitHub - PanJiaChen/vue-admin-template: a vue2.0 minimal admin template

1、路由(部分代码):


export const asyncRoutes = [
  {
    type: 'goods',
    path: '/goods',
    component: Layout,
    children: [{
      path: 'goods',
      component: () => import('@/views/goods/index'),
      name: '商品管理',
      meta: {
        title: '商品管理',
        icon: 'el-icon-goods'
      }
    }]
  },
  {
    type: 'members',
    path: '/members',
    component: Layout,
    children: [{
      path: 'members',
      component: () => import('@/views/members/index'),
      name: '会员管理',
      meta: {
        title: '会员管理',
        icon: 'el-icon-user'
      }
    }]
  },
  {
    type: 'order',
    path: '/order',
    component: Layout,
    children: [{
      path: 'order',
      component: () => import('@/views/order/index'),
      name: '订单管理',
      meta: {
        title: '订单管理',
        icon: 'el-icon-shoppingCard'
      }
    }]
  },
  // 404 page must be placed at the end !!!
  {
    path: '*',
    redirect: '/404',
    hidden: true
  }
]

2、侧边栏改造:

<template
      v-if="hasOneShowingChild(item.children,item) && (!onlyOneChild.children||onlyOneChild.noShowingChildren)&&!item.alwaysShow">
      <template v-if="item.type === $store.state.app.sidebar.topNavState">
        <app-link v-if="onlyOneChild.meta" :to="resolvePath(onlyOneChild.path)">
          <el-menu-item :index="resolvePath(onlyOneChild.path)" :class="{'submenu-title-noDropdown':!isNest}">
            <item :icon="onlyOneChild.meta.icon||(item.meta&&item.meta.icon)" :title="onlyOneChild.meta.title" />
          </el-menu-item>
        </app-link>
      </template>
    </template>

注意代码

item.type === $store.state.app.sidebar.topNavState

3、store改造

const state = {
  sidebar: {
    opened: Cookies.get('sidebarStatus') ? !!+Cookies.get('sidebarStatus') : true,
    withoutAnimation: false,
    topNavState: 'goods'
  },
  device: 'desktop',
  size: Cookies.get('size') || 'medium'
}

4、index.vue改造

<el-menu :default-active="activeIndex" class="el-menu-demo" mode="horizontal" @select="handleSelect">
        <el-menu-item index="1">商品</el-menu-item>
        <el-menu-item index="2">会员</el-menu-item>
        <el-menu-item index="3">订单</el-menu-item>
      </el-menu>


====================================================


/**
       * 监听导航菜单切换
       */
      handleSelect(key, keyPath) {
        // console.log(key, keyPath);
        // console.log("state=", this.$store.state)
        if (key === '1') {
          this.$store.state.app.sidebar.topNavState = 'goods';
          this.$router.push(`/`);
        } else if (key === '2') {
          this.$store.state.app.sidebar.topNavState = 'members';
          this.$router.push(`/members/members`)
        }
        // console.log("state=", this.$store.state)
        //缓存选中的导航菜单
        localStorage.setItem('topNavState', this.$store.state.app.sidebar.topNavState);
      },

====================================================

created() {
      this.userData = JSON.parse(localStorage.getItem('userData'));
      //获取本地缓存,选中之前选中的导航栏
      let topNavState = localStorage.getItem('topNavState');
      if (topNavState === 'members') {
        this.activeIndex = '2';
        this.$store.state.app.sidebar.topNavState = 'members';
      } else {
        this.activeIndex = '1';
        this.$store.state.app.sidebar.topNavState = 'goods';
      }
    },

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值