vue实现电商后台管理系统---(3)主页实现

本文详细介绍了一个电商后台管理系统的搭建过程,包括使用Vue和Element-UI创建主页布局,设计响应式侧边栏,以及实现二级菜单和路由切换。同时,文章还分享了退出功能的实现方式和菜单数据的动态加载。

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

首先展示一下主页的界面效果:
在这里插入图片描述
实现步骤与思路:
一、主页面:
(1)在Home.vue中设计主页面,分为头部、内容区,内容区里包含侧边栏以及主体内容区三大部分。内容区主要是使用侧边栏增加路由来实现。

  • 头部里包含一个logo,一个名称以及一个退出按钮。
  • 侧边栏:使用element-ui中的Menu来进行构建,有二级菜单。
  • 主体内容区:使用路由来获取相对应的内容并且进行展示。

代码:

<template>
    <el-container class="home-container">
        <!-- 头部区域 -->
    <el-header>
        <div>
            <img src="../assets/heima.png" alt="">
            <span>电商后台管理系统</span>
        </div>
        <el-button type="info" @click="quit">退出</el-button>
    </el-header>
    <!-- 内容区 -->
    <el-container>
        <!-- 侧边栏 -- 属性加冒号表示绑定一个值,不加值为字符串如unique-opened可以直接写为unique-opened不加属性值-->
        <el-aside :width="iscollapse?'64px':'200px'">
            <div class="toggle-button" @click="togglecollapse">|||</div>
             <el-menu
      background-color="#545c64"
      text-color="#fff"
      active-text-color="#ffd04b" :unique-opened="true" :collapse="iscollapse" 
      :collapse-transition="false" router :default-active="activepath">
      <el-submenu :index="item.id+''" v-for="item in menuList" :key = "item.id">
        <template slot="title">
            <!-- 一级菜单图标 -->
          <i :class="iconsObj[item.id]"></i>
            <!-- 一级菜单内容 -->
          <span>{{item.authName}}</span>
        </template>
        <!-- 二级菜单 -->
        <el-menu-item :index="'/'+subitem.path" v-for="subitem in item.children" :key="subitem.id" @click="getpath(subitem.path)">
            <template slot="title">
          <i class="el-icon-menu"></i>
          <span>{{subitem.authName}}</span>
        </template>
        </el-menu-item>
      </el-submenu>
    </el-menu>
        </el-aside>
        <!-- 右边内容区 -->
        <el-main>
            <!-- 路由占位符 -->
            <router-view></router-view>
        </el-main>
    </el-container>
</el-container>
</template>

<script>
export default {
    created(){
        this.showMenuList();
        // 设置当前的二级菜单
        this.activepath ='/'+ window.sessionStorage.getItem('activepath');
    },
    data:function(){
        return {
            // 左侧菜单数据
            menuList:[],
            // 一级菜单图标对象
            iconsObj:{
                '125':'iconfont icon-users',
                '103':'iconfont icon-tijikongjian',
                '101':'iconfont icon-shangpin',
                '102':'iconfont icon-danju',
                '145':'iconfont icon-baobiao'
            },
            // 菜单栏是否水平折叠
            iscollapse:false,
            // 当前激活的路径(第二级菜单栏)
            activepath:'',
        }
    },
    methods:{
        quit:function(){
            // 退出功能主要是利用清除token的原理来实现
            // 清除token
            window.sessionStorage.clear();
            // 退出后回到登录页面
            this.$router.push('/login');
            // 显示退出成功
            this.$message.success('退出成功');
        },
        showMenuList:async function(){
            // 展示左侧菜单列表
           const {data:res} =  await this.$http.get('menus');
            //console.log(res);
            if(res.meta.status != 200) return this.$message.error(res.meta.msg);
            this.menuList = res.data;
            console.log(this.menuList);
        },
        togglecollapse:function(){
            // 是否水平折叠菜单栏
            this.iscollapse = ! this.iscollapse;
        },
        getpath:function(val){
            // 获取点击二级菜单的路径
           // console.log(val);
           window.sessionStorage.setItem('activepath',val);
        //  this.activepath = '/'+val;
        }
    }
}
</script>

<style lang="less" scoped>
.home-container {
    height: 100%;
}
.el-header {
    background-color:#373D41;
    // 项目位于各行之间留有空白的容器内
    display: flex;
    justify-content: space-between;
    padding-left:0;
    color:#fff;
    font-size: 25px;
    // 纵向居中
    align-items: center;
    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;
}
.toggle-button {
    background-color:#4A5064;
    color:#fff;
    font-size:10px;
    line-height:24px;
    text-align: center;
    letter-spacing:0.3em;
    cursor: pointer;
}
</style>

二、欢迎页面:
在components文件夹下新建一个文件Welcome.vue。
代码:

<template>
    <div>
        <h1>welcome</h1>
    </div>
</template>

三、一些小细节

  • element.js文件中需要挂载的依赖不要忘记了挂载哦~
  • 路由规则也不要忘记配置。目前的路由导航规则如下:
const routes = [
    // 配置路由重定向
    { path: '/', redirect: '/login' },
    { path: '/login', component: Login },
    {
        path: '/home',
        component: Home,
        redirect: '/welcome',
        children: [
            { path: '/welcome', component: Welcome },
        ]
    }
]

我实在是太懒了,一直拖一直拖,现在要一鼓作气把它写完啊啊啊啊啊~~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值