vue中表格分页功能之切换页码居中效果(学会了至少提升500块身价)

该博客介绍了一个用于创建居中显示页码的JavaScript函数。函数根据总页数、每页大小、当前页码及显示按钮数量,动态生成一个页码数组,确保中间页码始终居中。在满足特定条件时,会调整数组长度和页码范围,确保结果合理。示例代码展示了不同场景下的应用,如不同起始页码和显示数量。
摘要由CSDN通过智能技术生成

一·封装一个使页码一直居中的函数

整体思路

  1. 先将一个中间页码 push 进一个数组里面,
  2. 往这个数组前面使用 unshift 往数组最前面添加一个比中间页码 -1 的数
  3. 往这个数组后面使用 pusht 往数组最后面添加一个比中间页码 +1 的数
  4. 直到达到所需的数组长度就终止添加

二· 具体代码

function f(total, size, page, btnCount = 5) {
  const num = Math.ceil(total / size)
  const arr = []
  if (btnCount > num) {
    btnCount = num
  }
  if (page > num) {
    page = num
  }
  arr.push(page)
  let qian = page
  let hou = page
  while (arr.length < btnCount) {
    if (qian > 1) {
      arr.unshift(--qian)
      if (hou < num && arr.length < btnCount) {
        arr.push(++hou)
      }
    }
  }
  return arr
}

//测试
/*
f(100, 10, 1,  5)  // ==> [1, 2, 3, 4, 5]
f(100, 10, 7,  5)  // ==> [5, 6, 7, 8, 9]
f(100, 10, 2,  5)  // ==> [1, 2, 3, 4, 5]
f(100, 10, 5,  5)  // ==> [3, 4, 5, 6, 7]
// 显示第十五页码的时候,因为当前最多只有是10页,所以最多只能显示到第 10 页
f(100, 10, 15 , 5)  // ==> [6, 7, 8, 9, 10]
//的页数只有 1 页  所以数组页只会显示一页
f(100, 100, 1, 5)   // ==> [1]

*/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值