讲师列表功能

55 阅读1分钟

1、创建文件 src/api/edu/teacher.js

import request from '@/utils/request'
export default {
  //带条件分页查询讲师列表
  getTeacherPageVo(current,limit,teacherQuery){
    return request({
      url: `/eduservice/eduteacher/getTeacherPageVo/${current}/${limit}`,
      method: 'post',
      data: teacherQuery//用json格式传输
    })
  }
}

2、在list.vue页面引入js,进行数据查询

<template>
  <div class="app-container">
    讲师列表
  </div>
</template>
<script>
import teacher from '@/api/teacher'
export default {
    data () {
        return {
            current:1,
            limit:10,
            teacherQuery:{}
        }
    },
    created () {
        this.getTeacherList()
    },
    methods: {
        getTeacherList(){
            teacher.getTeacherPageVo(this.current,this.limit,this.teacherQuery)
            .then(response=>{
                console.log(response)
            })
        }
    }
}
</script>

访问前端页面,F12查看控制台输出信息。 在这里插入图片描述

3、实现页面渲染

(1)添加页面元素

<!-- 表格 -->
    <el-table
      v-loading="listLoading"
      :data="list"
      element-loading-text="数据加载中"
      border
      fit
      highlight-current-row
    >
      <el-table-column label="序号" width="70" align="center">
        <template slot-scope="scope">{{ (current - 1) * limit + scope.$index + 1 }}</template>
      </el-table-column>

      <el-table-column prop="name" label="名称" width="80"/>

      <el-table-column label="头衔" width="80">
        <template slot-scope="scope">{{ scope.row.level===1?'高级讲师':'首席讲师' }}</template>
      </el-table-column>

      <el-table-column prop="intro" label="资历"/>

      <el-table-column prop="gmtCreate" label="添加时间" width="160"/>

      <el-table-column prop="sort" label="排序" width="60"/>

      <el-table-column label="操作" width="200" align="center">
        <template slot-scope="scope">
          <router-link :to="'/edu/teacher/edit/'+scope.row.id">
            <el-button type="primary" size="mini" icon="el-icon-edit">修改</el-button>
          </router-link>
          <el-button
            type="danger"
            size="mini"
            icon="el-icon-delete"
            @click="removeDataById(scope.row.id)">删除</el-button>
        </template>
      </el-table-column>
    </el-table>

(2)修改原有的js方法

<script>
import teacher from "@/api/teacher";
export default {
  data() {
    return {
      current: 1,
      limit: 10,
      teacherQuery: {},
      list:[]
    };
  },
  created() {
    this.getTeacherList();
  },
  methods: {
    getTeacherList() {
      teacher
        .getTeacherPageVo(this.current, this.limit, this.teacherQuery)
        .then(response => {
          console.log(response);
          this.list = response.data.items
        });
    }
  }
};
</script>