vue 数据手写分页算法,定时展示

news2024/11/16 5:31:09

我们在业务之中,其实会常常用到一些数据的分段展示 , 比如数据量过大导致echarts无法展示,我们就可以将数据进行算法分页 , 然后套用定时器实时更新分段数据;

例子展示 : 将下列数组截取成每页5条数据的分页效果 , 要求定时轮播不同页数的渲染数据

    this.arr = [
      { name: '1', id: '1' },
      { name: '2', id: '2' },
      { name: '3', id: '3' },
      { name: '4', id: '4' },
      { name: '5', id: '5' },
      { name: '6', id: '6' },
      { name: '7', id: '7' },
      { name: '8', id: '8' },
      { name: '9', id: '9' },
      { name: '10', id: '10' },
      { name: '11', id: '11' },
    ]

接下来请看我提供给你的效果图 , 如果你也需要,请耐心看完这篇讲解哟~
在这里插入图片描述

开发思路 :

  1. 定义页数变量与总页数变量 这两个变量后期可以帮助我们进行数据的重置
  2. 定义定时器标识 , 后期帮助我们定时展示

分页思路:

  1. 算出总页数:
    总页数 = 数组长度和每页多少条取余 , 如果余为0,说明整除 , 直接返回(数组长度/每页条数),如果余不为0,就说明有一页不满足每页最大条数,我们返回(数组长度/每页条数+1)即可
    相当于 :
    数组长度11
    我设定每页条数5
    那么就是余下1 , 余数不为0,直接就是(11/5+1)= 3 页 , 第三页展示的数据就是余下的那条数据

  2. 拿到每页数据
    我们通过数组的 slice(从哪开始[索引] , 截止到哪结束[索引]),获取截取的每页数据
    从哪儿开始的索引 :(当前所在的页数-1)5
    原因是 :
    如果现在是第一页 , 那我们获取的索引就是 (1-1)5 = 0, 也就是第一页的数据我们从索引为0的数据项开始截取
    如果现在是第二页 , 那我们获取的索引就是 (2-1)5 = 0, 也就是第一页的数据我们从索引为5的数据项开始截取
    原因是 : 开始的时候我们设定的每页条数是5 , 那么从数组索引为5,也就是第6个数据开始截取作为第二页的第一个数据 , 这样以此类推

    截止到哪结束[索引]:当前所在页数
    5
    原因是 :
    如果现在是第一页 , 那我们获取的索引就是 1
    5 = 5, 将作为我们截止到哪儿的结束索引 , 因为数组的slice方法 , 只是截止到截止到哪结束[索引]的前一个索引 , 我们获取的是5 , 那么实际上就是截取到了索引为 0 1 2 3 4 这五条数据作为第一页数据的展示数据用
    如果现在是第二页 , 那我们获取的索引就是2
    5 = 10 , 也就是会截取到索引为 5 6 7 8 9的数据作为第二页的数据,这样以此类推

  3. 定时之展示
    定义定时器 , 触发定时器的时候 , 让所在当前页自动+1 , 判断如果所在当页大于了总页面就重置为1,从第一页开始展示和获取数据即可

    接下来是完整代码 , 你可以根据我的注解 , 了解其中运行规则


data(){
  return{
      arr: [], // 需要分页的数据
      currentPage: 1, // 当前页数
      totalPage: 0, // 总页数 - 需要计算,每页显示5个
      timeId:0, // 定时器标识
  }
}mounted(){
    // 模拟数据
    this.arr = [
      { name: '1', id: '1' },
      { name: '2', id: '2' },
      { name: '3', id: '3' },
      { name: '4', id: '4' },
      { name: '5', id: '5' },
      { name: '6', id: '6' },
      { name: '7', id: '7' },
      { name: '8', id: '8' },
      { name: '9', id: '9' },
      { name: '10', id: '10' },
      { name: '11', id: '11' },
    ]
    // 开始执行函数和逻辑 - 打开控制台看运行数据即可
    this.totalData()},
methods:{
    // 获取总页数
    totalData() {
      // 总页数 = 数组长度和每页多少条取余 , 如果余数是0 , 代表正好 , 如果不是0,就在总页数上+1 , 即可得出总页数
      this.totalPage = this.arr.length % 5 == 0 ? parseInt(this.arr.length / 5) : parseInt(this.arr.length / 5 + 1);
      console.log('总页数',this.totalPage )
      // 调用定时器
      this.startInterval();
    },
    // 获取每页数据
    onePageData(){
      // 开始 - 第一页就是0,第二页就是5...10
       const start = (this.currentPage - 1)*5

      // 结束 - 当前页*5 - 截取到什么 第一页就是截取到5...10...15
      const end = this.currentPage*5
      // 截取到当页的需要渲染的数据
      const showData = this.arr.slice(start,end);

      console.log(start,end,showData)
    },

    // 封装定时器
    startInterval(){
      // 3秒一执行
      if(this.timeId){
        clearInterval(this.timeId)
      }
     
      this.timeId = setInterval(()=>{
        // 每次隔着时间都自定执行获取需要的每页数据 , 放在这是为了第一次可以获取到
        this.onePageData();
        // 每次隔着时间执行都自动进行翻页
        this.currentPage++
        // 当前页数超过了总页数就恢复成第一页即可
        if(this.currentPage>this.totalPage){
          this.currentPage = 1;
        }
      },3000)

    },
}




如果你耐心看完了就自己写一写,分页其实可以很好的锻炼逻辑思维 , 加油!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/71063.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

鞋子商店APP源码和设计报告

实 验 报 告 课程名称 实验名称 指导教师 专业 班级 学号 姓名 一、需求分析 1.需求分析 随着互联网和手机技术的蓬勃发展,网购已经成为许多人,尤其是年轻人的主要消费方式,这就对手机购物APP产生了大量的需求,商品的展…

01入门-ThreadLocal详解-并发编程(Java)

文章目录1 简介2 基本使用2.1 常用方法2.2 小案例3 ThreadLocal与Sycronized4 应用场景4.1 转账案例构建4.2 问题4.3 解决5 后记1 简介 官方JDK源码关于ThreadLocal描述:ThreadLocal类用来提供线程内部的局部变量。这种变量在多线程环境下访问(通过get和…

【opensips】客户端的注册

opensips的注册能力 opensips可以通过registrar模块实现注册的能力, 所有的账户信息默认是在opensips的subscibe表中, 默认的subscibe表结构如上图, id是主键,username是账户名domain是opensips的域名password是密码email_addre…

ChatGPT 全网最新开通账号教程

🦆博主介绍:小黄鸭技术 🌈擅长领域:Java、实用工具、运维 👀 系列专栏:📢开发工具 Java之路 八股文之路 📧如果文章写作时有错误的地方,请各位大佬指正,一起进…

掌握Redis的Sentinel哨兵原理,助你拿到25k的offer

— — | M1 |---------| R1 | | S1 | | S2 | — — Configuration: quorum 1 master宕机,s1和s2中只要有1个哨兵认为master宕机就可以进行切换,同时会在s1和s2中选举出一个执行故障转移. 但此时,需要majority,也就是大多数…

微信小程序开发笔记 进阶篇⑥——getPhoneNumber 获取用户手机号码(基础库 2.21.2 之后)

文章目录一、前言二、前端代码wxml三、前端代码js四、后端java五、程序流程六、参考一、前言 大部分微信小程序开发者都会有这样的需求:获取小程序用户的手机号码。但是,因为小程序用户的手机号码属于重要信息,为了安全,所以需要如…

细粒度图像分类论文研读-2022

文章目录TransFG: A Transformer Architecture for Fine-grained RecognitionAbstractintroductionMethodVision transformer as feature extractorImage SequentializationPatch EmbeddingTransFG ArchitecturePart Selection ModuleConstrastive feature learningViT-FOD&…

从理论走向实战,阿里高工熬夜整理出的 Spring 源码速成笔记太香了

不知道大家面试的时候有没有被问到过 Spring 相关问题(循环依赖、事务、生命周期、传播特性、IOC、AOP、设计模式、源码)?反正我这个小学弟前段时间就来私信我说自己面试挂在了 Spring 这一块。(原谅我不厚道地笑了,如…

毕设选题推荐基于python的django框架的自媒体社推广平台系统

💖🔥作者主页:计算机毕设老哥🔥 💖 精彩专栏推荐订阅:在 下方专栏👇🏻👇🏻👇🏻👇🏻 Java实战项目专栏 Python实…

安卓APP源码和设计报告——运动健身教学

实 验 报 告 课程名称 实验名称 指导教师 专业 班级 学号 姓名 目 录 一、设计背景31. 需求分析32. 课题研究的目的和意义3二、系统需求分析与开发环境31. 系统功能需求32.系统界面需求43.开发环境4三、系统设计4四、系统测试51.脑模拟器测试6五、总结与展望6六、重要…

YoloV7目标检测(Pytorch版)【详解】

文章目录一、网络结构1、总体网络结构(backbone)2、主干网络介绍(backbone)2.1 多分支模块堆叠2.2 下采样网络结构2.3 整个backbone代码3、FPN特征金字塔二、预测结果的解码一、网络结构 1、总体网络结构(backbone&am…

【组件开发实践】云巧流程组件对接实践

1. 用户需求 假设A系统有如下员工请假审批流场景: 员工请假小于等于3天,只需主管直接审批;大于3天需要主管先审批,审批通过后再由二级主管进行审批。当员工请假审批流节后后,需要通知A系统进行业务处理(例…

Tomcat的IO模型

Tomcat支持一下几种IO模型: 支持的IO模型 特点 BIO 同步阻塞式IO,每一个请求都会创建一个线程,对性能开销大,不适合高并发场景。 NIO 同步非阻塞式IO,基于多路复用Selector监测连接状态通知线程处理,…

<C++>多态

文章目录1. 概念2. 多态的定义和实现2.1 多态的构成条件2.2 虚函数2.3 虚函数的重写2.4 虚函数重写的两个例外:2.5 C11 override和final2.6 重载、覆盖(重写)、隐藏(重定义)的对比3. 抽象类3.1 概念3.2 接口继承和实现继承3. 多态的原理3.1 虚函数表3.2 多态的原理3…

S2SH小区物业管理系统计算机专业毕业论文java毕业设计网站

💖💖更多项目资源,最下方联系我们✨✨✨✨✨✨ 目录 Java项目介绍 资料获取 Java项目介绍 《S2SH小区物业管理系统》该项目采用技术:jsp struts2springhibernatecssjs等相关技术,项目含有源码、文档、配套开发软件…

java EE初阶 — wait 和 notify

文章目录1.wait 和 notify1.1 wait()方法1.2 notify()方法1.3 notifyAll()方法1.wait 和 notify 线程最大的问题是抢占式指向,随机调度。而写代码的时候,确定的东西会比较好。 于是就有程序猿发明了一些办法,来控制线程之间的执行顺序。 虽…

火山引擎 RTC 助力抖音百万并发“云侃球”

动手点关注干货不迷路1. 背景及技术挑战从电视看直播到手机电脑看直播,直播技术的发展让观众可以随时、随地观看自己喜欢的比赛,并且在看比赛时通过发送表情、发文字进行互动。但表情、文字承载的信息量较小、沟通效率低,我们无法像线下一起看…

一大波节日来袭,App Store节日营销请注意!

11 月已经过去,在过去的 11 月里,我们经历了万圣节、双 11、世界杯、感恩节、黑色星期五等非常重要的营销节点。 在新的 12 月,我们将迎来世界杯闭幕、双12、平安夜、圣诞节等重要营销机遇。在未来,我们还会迎来新春营销的重要机…

图形API学习工程(29):解决在shader文件中使用include的问题

工程GIT地址:https://gitee.com/yaksue/yaksue-graphics 无用的前言 看了下提交记录,这个工程上次更新已经是一年以前了。最近想想,还是应该回来再继续学学,暂且不论是否对工作有帮助,我在这个工程上获得的愉悦感相比…

Excel 是您最容易被忽视的设计工具 设计师对世界排名第一的电子表格工具的看法——如何构建信息图表、仪表板、演示文稿等

人们对 Excel 有很多误解。许多人认为它不过是处理临时预算的电子表格工具。或者它非常适合处理数据,但您需要像 PowerPoint 这样的单独工具才能很好地显示它。 这些误解限制了我们使用 Excel 的方式。 但 Excel 的功能远不止于此,它所需要的只是了解一些鲜为人知的功能。我…