前端删除列表数据后页码重置逻辑

问题描述

需要调整页码的例子:
列表一共有10页数据,用户把第10页数据全部删除后,需要把数据重置成上一页,也就是第9页
在这里插入图片描述

不用调整页码的例子:
列表一共有1页数据,用户把本页数据全部删除后,页码依然是第1页无需调整
在这里插入图片描述

代码

列表数据删除后,对当前页码进行修正,防止有数据时,因页码错误导致页面显示不出数据
当前页current为最大页码时进行调整(并且排除掉第一页的情况)

  data(){
    return {
      tableData: [],//数据列表
      current: 1,//当前页码
      pageSize: 10,//每页条数
      total: 0,//总条数
    }
  },
  methods: {
    /** 获取列表数据 */
    getTableData(){ ... },
    /** 删除数据 */
    handleDel(){
      const ids = [1, 2, 3]//要删除数据的id(当前代码为demo所以是写死的id列表)
      const params = { ids }
      // 调用删除接口
      DelData(params).then((res)=>{
        if(res.code==200){
          //当前页码(current)大于一页,并且为最后一页时需要重置页码
          const maxCurrent = Math.ceil(this.total/this.pageSize)//最大页码
          if(
	          (ids.length == this.tableData.length) &&
	          (this.current > 1) && //排除第一页
	          (this.current == maxCurrent) //排除所有中间页
	        ){
            this.current -= 1
          }

          // 页码修正后再获取列表数据
          this.getTableData()
        }
      })
    }
  }

相关推荐

  1. @TableLogic注解逻辑删除查已删除数据

    2024-03-26 10:08:05       37 阅读
  2. vue 页面刷新、、更新页面所有数据

    2024-03-26 10:08:05       75 阅读
  3. 如何woocommerce,如何批量删除woocommerce产品

    2024-03-26 10:08:05       38 阅读
  4. React18-列表数据实现用户删除、批量删除

    2024-03-26 10:08:05       54 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-26 10:08:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-26 10:08:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-26 10:08:05       82 阅读
  4. Python语言-面向对象

    2024-03-26 10:08:05       91 阅读

热门阅读

  1. 28.找出字符串中第一个匹配项的下标

    2024-03-26 10:08:05       38 阅读
  2. MySQL数据结构B树与B+树的区别

    2024-03-26 10:08:05       47 阅读
  3. Rust 的 HashMap 特定键值元素值的累加方法

    2024-03-26 10:08:05       43 阅读
  4. 007、IronPython与.NET Framework

    2024-03-26 10:08:05       35 阅读
  5. Matlab中mpower函数用法

    2024-03-26 10:08:05       45 阅读