elementui的table和pagination表格和分页一起使用

<template>
  <div>
    <!-- 表格 -->
    <el-table :data="tableData" style="width: 100%">
      <el-table-column prop="date" label="日期" width="180"> </el-table-column>
      <el-table-column prop="name" label="姓名" width="180"> </el-table-column>
      <el-table-column prop="address" label="地址"> </el-table-column>
    </el-table>
    <!-- 分页 -->
    <el-pagination
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
      :current-page="pagenum"
      :page-sizes="[10, 20, 30, 40]"
      :page-size="pagesize"
      layout="total, sizes, prev, pager, next, jumper"
      :total="total"
    >
    </el-pagination>
  </div>
</template>

<script>
export default {
  data() {
    return {
      tableData: [],
      // 分页数据
      pagenum: 1, // 当前页数
      pagesize: 10, // 每页显示条目个数
      total: 0, // 总条目数
    };
  },
  created() {
	this.getList()
  },
  methods: {
    async getList() {
      const res = await this.$http.get("请求数据的接口", { // this.$http是自己封装的axios请求
        params: { // 请求的参数
          pagenum: this.pagenum,
          pagesize: this.pagesize,
        },
      });
      if (res.code === 200) { // 请求成功后赋值
        this.tableData = res.data;
        this.total = res.data.total;
      }
    },
    // 当每页条数改变时,重新赋值pagenum,再请求一次数据
    handleSizeChange(val) {
      this.pagesize = val;
      this.getList();
      console.log(`每页 ${val} 条`);
    },
    // 选择下一页或者跳到第几页,重新赋值pagenum,再请求一次数据
    handleCurrentChange(val) {
      this.pagenum = val;
      this.getList();
      console.log(`当前页: ${val}`);
    },
  },
};
</script>

<style></style>

你可能感兴趣的:(vue)