zoukankan      html  css  js  c++  java
  • 2021年5月27日

    时间:4个小时左右

    代码:300行左右

    博客:2

    学习内容:后台首页的基本布局、左侧菜单栏、用户列表

    <template>
        <el-container class="home-container">
          <!-- 头部区域 -->
          <el-header>
            <div>
              <!-- 黑马logo -->
              <img src="../assets/heima.png" alt="">
              <!-- 顶部标题 -->
              <span>电商后台管理系统</span>
            </div>
            <el-button type="info" @click="logout"> 退出 </el-button>
          </el-header>
          <!-- 页面主体区域 -->
          <el-container>
            <!-- 侧边栏 -->
            <el-aside width="200px">
              <!-- 侧边栏菜单 -->
              <el-menu
                background-color="#333744"
                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 index="1-4-1">
                    <!-- 二级菜单模板 -->
                    <template slot="title">
                      <!-- 图标 -->
                      <i class="el-icon-location"></i>
                      <!-- 文本 -->
                      <span>子菜单一</span>
                    </template>
                  </el-menu-item>
                </el-submenu>
                
              </el-menu>
            </el-aside>
            <!-- 主体结构 -->
            <el-main>Main</el-main>
          </el-container>
        </el-container>
    </template>

    /请求在到达服务器之前,先会调用use中的这个回调函数来添加请求头信息
    axios.interceptors.request.use(config=>{
    //为请求头对象,添加token验证的Authorization字段
    config.headers.Authorization = window.sessionStorage.getItem("token")
    return config
    })
    ```

    ###4.请求侧边栏数据
    ```
    <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>

    <el-menu
    background-color="#333744"
    text-color="#fff"
    active-text-color="#ffd04b">
    <!-- 一级菜单 -->
    <el-submenu :index="item.id+''" v-for="item in menuList" :key="item.id">
    <!-- 一级菜单模板 -->
    <template slot="title">
    <!-- 图标 -->
    <i class="el-icon-location"></i>
    <!-- 文本 -->
    <span>{{item.authName}}</span>
    </template>
    <!-- 二级子菜单 -->
    <el-menu-item :index="subItem.id+''" v-for="subItem in item.children" :key="subItem.id">
    <!-- 二级菜单模板 -->
    <template slot="title">
    <!-- 图标 -->
    <i class="el-icon-location"></i>
    <!-- 文本 -->
    <span>{{subItem.authName}}</span>
    </template>
    </el-menu-item>
    </el-submenu>
    </el-menu>

    <!-- 侧边栏,宽度根据是否折叠进行设置 -->
            <el-aside :width="isCollapse ? '64px':'200px'">
              <!-- 伸缩侧边栏按钮 -->
              <div class="toggle-button" @click="toggleCollapse">|||</div>
              <!-- 侧边栏菜单,:collapse="isCollapse"(设置折叠菜单为绑定的 isCollapse 值),:collapse-transition="false"(关闭默认的折叠动画) -->
              <el-menu
              :collapse="isCollapse"
              :collapse-transition="false"
    <script>
    export default {
      data() {
        return {
          //获取查询用户信息的参数
          queryInfo: {
            query: '',
            pagenum: 1,
            pagesize: 2
          },
          //保存请求回来的用户列表数据
          userList:[],
          total:0
        }
      },
      created() {
        this.getUserList()
      },
      methods: {
        async getUserList() {
          //发送请求获取用户列表数据
          const { res: data } = await this.$http.get('users', {
            params: this.queryInfo
          })
          //如果返回状态为异常状态则报错并返回
          if (res.meta.status !== 200)
            return this.$message.error('获取用户列表失败')
          //如果返回状态正常,将请求的数据保存在data中
          this.userList = res.data.users;
          this.total = res.data.total;
        }
      }
    }
    </script>
  • 相关阅读:
    mysql 优化20点
    java function
    设计模式 概览
    Linux安装java1.8并配置环境变量
    windows下一次执行多个sql文件
    mybatis查询结果为空时的返回值问题
    Java中Json与String互转
    SSM Service自动注入失败
    本地安装Mysql5.7过程中出现的一系列问题
    解决本地工具无法连接服务器上的mysql的问题
  • 原文地址:https://www.cnblogs.com/j-y-s/p/14903360.html
Copyright © 2011-2022 走看看