Vue的电商后台管理系统(2)

本文是Vue电商后台管理系统系列的第二部分,主要介绍如何从后端获取后台列表数据并渲染,实现用户列表的展示、修改、删除和添加等功能。包括使用Element UI的Container和NavMenu布局,设置二级目录路由,制作侧边栏菜单的伸缩,添加子级路由,绘制用户列表结构,请求和分页展示用户数据,实现搜索、添加用户和修改用户状态的功能。
摘要由CSDN通过智能技术生成

Vue的电商后台管理系统(2)

上一节已经实现该系统的登陆界面、路由、登录、退出及导航守卫功能,本期将继续完善该系统的以下功能:从后端获取后台列表数据并渲染到前端页面、用户列表的展示、修改、删除和添加。

1.后台首页基本布局

本系统后台将采用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>

侧边栏布局

侧边栏的目录结构采用Element UI 中的NavMenu导航菜单。

代码框架:

 <el-menu
      default-active="2"
      class="el-menu-vertical-demo"
      @open="handleOpen"
      @close="handleClose">
      <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>

侧边栏数据渲染

<script>
export default {
   
  data() {
   
    return {
   
      // 左侧菜单数据
      menuList: null
    }
  },
  created() {
   
    // 在created阶段请求左侧菜单数据
    this.getMenuList()
  },
  methods: {
   
  //退出
    logout() {
   
      window.sessionStorage.clear()
      this.$router.push('/login')
    },
    async getMenuList() {
   
      // 发送请求获取左侧菜单数据
      const {
    data: res } = await this.$http.get('menus')
      if (res.meta.status !== 200) return this.$message.error(res.meta.msg)
 
      this.menuList = res.data
      console.log(res)
    }
  }
}
</script>

通过遍历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="el-icon-menu"></i>
                  <span>{
   {
   subItem.authName
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值