vue使用ElementUI el-pagination实现分页

<el-pagination
        background
        @size-change="handleSizeChange"
        @current-change="handleCurrentChange"
        :current-page="filter.page"
        :page-sizes="[10, 15, 30, 50, 100, 200]"
        :page-size.sync="filter.size"
        layout="total, sizes, prev, pager, next, jumper"
        :total="aptotalNum"
        class="table-pagination"
      >
</el-pagination>

export default {
  components: {
    CreateUpdate,
  },
  props: {
    formId: {
      type: Number,
      default: 0,
    },
  },
  data() {
    return {
      tableData: [],
      filter: {
        query: "",
        page: 1,
        size: 10
      },
      aptotalNum: 0,
    };
  },
  methods: {
    handleSizeChange(size) {
      this.filter.size = size;
      this.getList();
    },
    handleCurrentChange(page) {
      this.filter.page = page;
      this.getList();//每次修改页面条数或页数都应执行回调表格数据接口
    },

重点:在表格中删除数据时,如果恰巧删除的是第11/21条,且现在设置的每页条数为10条,表格将不显示数据,因为后端只返回当前页数据,这时需要前端进行动态判断

if (
  (this.aptotalNum - deleteIds.length + 1) %
     this.filter.size ===
   1
 ) {
   this.filter.page = this.filter.page - 1;
 }

判断语句应写在删除方法中,当删除成功后进行二次判断是否需要执行page-1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值