没有高亮效果
default-active | 当前激活菜单的 index | string | — | — |
将index给 default-active就高亮了
default-active="/users"
但是就写死了,那么如何改进呢,将每次点击链接的时候,将对应的path的值保存都sessionstroge中,当刷新页面的时候,可以将值取出来动态赋值给default-active
给二级菜单绑定事件
<el-menu-item :index="'/'+j.path" v-for="j in i.children"
:key="j.id" @click="saveNavState('/'+j.path)">
saveNavState(activePath){
window.sessionStorage.setItem('activePath',activePath)
}
动态绑定+刷新页面,高亮任然存在,并且点击页面页高亮
<template>
<el-container class="home-container">
<!-- el-header头部区域 -->
<el-header>
<div>
<img src="../assets/home页面.jpg" alt="">
<span>电商后台管理系统</span>
</div>
<el-button type="info" @click="logout">退出</el-button>
</el-header>
<!-- el-container主体区域 -->
<el-container>
<!-- el-aside侧边栏 -->
<el-aside :width="isCollapse?'64px':'200px'">
<!-- 折叠 -->
<div class="togole-button" @click="toggleCollapse">|||</div>
<!-- 侧边栏菜单区域 -->
<!-- 背景颜色 :unique-opened加:才是布尔值-->
<el-menu background-color="#333744" text-color="#fff"
active-text-color="#409eff" :unique-opened="true" :collapse="isCollapse"
:collapse-transition="false" router
:default-active='activePath'>
<!-- 动态绑定 :index需要字符串格式 -->
<el-submenu :index="i.id + ''" v-for="i in menulist"
:key="i.id">
<!-- 一级菜单 -->
<template slot="title">
<!-- 一级菜单图标 -->
<i :class="iconsObj[i.id]"></i>
<!-- 一级菜单文本 -->
<span>{{i.authName}}</span>
</template>
<!-- 二级菜单 -->
<el-menu-item :index="'/'+j.path" v-for="j in i.children"
:key="j.id" @click="saveNavState('/'+j.path)">
<template slot="title">
<!-- 二级菜单图标 -->
<i class="el-icon-menu"></i>
<!-- 二级菜单文本 -->
<span>{{j.authName}}</span>
</template>
</el-menu-item>
</el-submenu>
</el-menu>
</el-aside>
<!-- el-main右侧内容 -->
<el-main>
<!-- 路由占位符 -->
<router-view></router-view>
</el-main>
</el-container>
</el-container>
</template>
<script>
export default{
data(){
//左侧菜单数据
return{
menulist:[],
//将id和类名对应起来
iconsObj:{
'125':'iconfont icon-yonghu',
'103':'iconfont icon-tijikongjian',
'101':'iconfont icon-shangpin',
'102':'iconfont icon-danju',
'145':'iconfont icon-baobiao',
},
//不折叠
isCollapse:false,
//被激活链接地址
activePath:''
}
},
created() {
//一进入获取所有菜单
this.getMenuList(),
//一被创建的时候就获取
this.activePath=window.sessionStorage.getItem('activePath')
},
methods: {
logout(){
window.sessionStorage.clear()
this.$router.push('/login')//重定向到登录页面
},
async getMenuList(){ //获取所有菜单
//promise数据
//重命名async
const{data:res} =await this.$http.get('menus')
//挂载到data中 便于渲染
if(res.meta.status!==200) return this.$message(res.meta.msg)
this.menulist=res.data
console.log(res.data) //试左侧收到的数据
},
toggleCollapse(){//点击按钮切换菜单折叠和展开
this.isCollapse=!this.isCollapse
},
saveNavState(activePath){
window.sessionStorage.setItem('activePath',activePath)
this.activePath=activePath
}
},
}
</script>
<style lang="less" scoped>
.home-container{
/* 实现全屏 */
height: 100%;
}
.el-header{
background-color: #343d41;
display: flex;
justify-content: space-between;/*此时会留有空白*/
margin-left: -20px;/*padding失效*/
align-items: center;/*按钮上下居中*/
/*文本*/
color: #fff;
font-size: 20px;
>div{
/*文本居中*/
display: flex;
align-items:center;
span{
margin-left: 15px;
}
}
}
.el-aside{
background-color: #333744;
.el-menu{
border-right: none;
}
}
.el-main{
background-color: #eaedf1;
}
.iconfont{
margin-right: 10px;
}
.togole-button{
background-color: #4a5064;
color:#fff;
font-size: 10px;
line-height: 24px;
text-align: center;
letter-spacing: 0.2em; /*字和字之间的距离 */
cursor: pointer;/*鼠标上去变成小手*/
}
</style>