电商后台管理系统2
前言
上期已经实现该系统的登陆界面、路由、登录、退出及导航守卫功能,本期将继续完善该系统的以下功能:从后端获取后台列表数据并渲染到前端页面、用户列表的展示、修改、删除和添加。
后台页面布局
本系统后台将采用Element UI 中的Container布局容器。
基本结构如下:

代码框架:
<el-container>
<el-header>Header</el-header>
<el-container>
<el-aside width="200px">Aside</el-aside>
<el-main>Main</el-main>
</el-container>
</el-container>
经过简单的HTML+CSS美化后,界面如下:

侧边栏美化
侧边栏的目录结构采用Element UI 中的NavMenu导航菜单。
基本效果如下:

代码框架:
<el-menu
default-active="2"
background-color="#545c64"
text-color="#fff"
active-text-color="#ffd04b">
<el-submenu index="1">
<template slot="title">
<i class="el-icon-location"></i>
<span>导航一</span>
</template>
<el-menu-item-group>
<template slot="title">分组一</template>
<el-menu-item index="1-1">选项1</el-menu-item>
<el-menu-item index="1-2">选项2</el-menu-item>
</el-menu-item-group>
<el-menu-item-group title="分组2">
<el-menu-item index="1-3">选项3</el-menu-item>
</el-menu-item-group>
<el-submenu index="1-4">
<template slot="title">选项4</template>
<el-menu-item index="1-4-1">选项1</el-menu-item>
</el-submenu>
</el-submenu>
<el-menu-item index="2">
<i class="el-icon-menu"></i>
<span slot="title">导航二</span>
</el-menu-item>
<el-menu-item index="3" disabled>
<i class="el-icon-document"></i>
<span slot="title">导航三</span>
</el-menu-item>
<el-menu-item index="4">
<i class="el-icon-setting"></i>
<span slot="title">导航四</span>
</el-menu-item>
</el-menu>
稍作更改,变换图标后,界面如下:

侧边栏数据渲染
根据后台API接口知后台菜单列表:

在加载后台列表前,需通过get方式得到后台响应的数据,才能将数据渲染至侧边菜单栏。
故在模板渲染成HTML页面前,调用created(),在其中完成后台菜单栏数据的获取,即getMenuList()
async getMenuList() {
const{
data: res } = await this.$http.get('menus')
//若获取数据失败 则返回错误信息
if(res.meta.status !== 200) return this.$message.error(res.meta.msg)
//将获取的数据存放至menulist中
this.menulist = res.data
}
设置拦截器,拦截每一次请求:
axios.interceptors.request.use(config => {
config.headers.Authorization = window.sessionStorage.getItem('token')
return config
})
通过遍历menulist中的数据,将其渲染至前端页面
<!-- 侧边栏区域 -->
<el-aside width="200px">
<el-menu default-active="1" background-color="#333744" text-color="#fff" active-text-color="#409EFF">
<!-- 一级菜单 -->
<el-submenu v-for="item in menulist" :index="item.id + ''" :key="item.id">
<template slot="title">
<i :class="iconsObj[item.id]"></i>
<span>{
{item.authName}}</span>
</template>
<!-- 二级菜单 -->
<el-menu-item v-for="subItem in item.children" :index="'/' + subItem.path + ''" :key="subItem.id">
<template slot="title">
<i class

最低0.47元/天 解锁文章
1010

被折叠的 条评论
为什么被折叠?



