前端分页处理
页面中实现的分页效果,要么后端提供接口,每次点击下一页就调用接口,若不提供接口,分页得前端自己去截取。

方法一:slice方法
 slice(参数1,参数2)方法是返回一个新的数组对象,左开右闭
 参数1:起始下标数
 参数2:结束下标数(不计算在内)
 如data:[1,2,3,4,5,6,7,8],那么data.slice(0,3)就为下标为0,1,2,不包括下标为3的数,即[1,2,3],可以看成数学中的[0,3)
slice方法详细讲解
这个原理就和分页原理很相似,分页也是把一个很长的数组,按照每页多少条(size)分为若干个短数组
//allData为全部数据,tableData是目前表格绑定的数据
(this.page - 1) * this.size,
this.page * this.size
);
this.total=this.allData.length
 下面是详细代码:


 比如:data=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19]
 总条目数total=20,
 若设size=3(每页3条)
 
 
 方法二:splice方法
 splice方法可以理解为删除,与方法一的slice只差一个p字母
 用splice分页,需要用到的有2个参数,
 splice(参数1,参数2)
 参数1:从第几位开始
 参数2:删除几个元素
 如data:[1,2,3,4,5,6,7,8],那么data.splice(0,3)就是从第0位开始,删除3个元素,即删除的元素为[1,2,3],剩余元素为data:[4,5,6,7,8],此方法会改变原数组
splice方法详细讲解
这个原理要和分页原理结合关联起来,如果一页3条数据,第一页就是从0位开始,删除的3个元素,即splice(0,3),第二页就是从第3位开始,删除的3个元素,即splice(3,3)
 因此用splice分页的关键语句就是:
let data=JSON.parse(JSON.stringify(this.allData))
this.tableData = data.splice(
(this.page - 1) * this.size,
this.size
);
this.total=this.allData.length
注意:splice会改变原数组,因为它使用一次,相当于原数组就被删除了一些元素,必须使用深拷贝先拷贝一份allData,然后再取被删除的元素赋值给tableData 。
其余代码不变,只是略微改变处理完整数据的方法

比如:
 data=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19]
 由于深拷贝的原因,data可以等于完整的allData,
 总条目数total=20,
 若设size=3(每页3条)

两种方法的总结
最后完整代码如下:
- <template>
-   <div>
-     <el-table :data="tableData" border>
-       <el-table-column label="序号" type="index" width="50">
-       </el-table-column>
-       <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="sizeChange" @current-change="currentChange"
- :current-page="page" :page-size="size" :page-sizes="pageSizes"
- layout="total, sizes, prev, pager, next, jumper" :total="total">
-     </el-pagination>
-   </div>
- </template>
- <script>
- export default {
- data() {
-     return {
-       page: 1, //第几页
-       size: 3, //一页多少条
- total: 0, //总条目数
- pageSizes: [3, 5, 10, 20, 50, 100, 200, 300, 400, 500, 1000], //可选择的一页多少条
- tableData: [], //表格绑定的数据
- allData: [
- {
-           date: "2016-05-02",
- name: "王小虎1",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎2",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎3",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎4",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- {
-           date: "2016-05-02",
- name: "王小虎5",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎6",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎7",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎8",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- {
-           date: "2016-05-02",
- name: "王小虎9",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎10",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎11",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎12",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- {
-           date: "2016-05-02",
- name: "王小虎13",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎14",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎15",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎16",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- {
-           date: "2016-05-02",
- name: "王小虎17",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎18",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎19",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎20",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- {
-           date: "2016-05-02",
- name: "王小虎21",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎22",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎23",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎24",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- {
-           date: "2016-05-02",
- name: "王小虎25",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎26",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎27",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎28",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- {
-           date: "2016-05-02",
- name: "王小虎29",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎30",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎31",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎32",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- {
-           date: "2016-05-02",
- name: "王小虎33",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎34",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎35",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎36",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- {
-           date: "2016-05-02",
- name: "王小虎37",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎38",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎39",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎40",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- {
-           date: "2016-05-02",
- name: "王小虎41",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎42",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎43",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎44",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- {
-           date: "2016-05-02",
- name: "王小虎45",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎46",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎47",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎48",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- {
-           date: "2016-05-02",
- name: "王小虎49",
-           address: "上海市普陀区金沙江路 1518 弄",
- },
- {
-           date: "2016-05-04",
- name: "王小虎50",
-           address: "上海市普陀区金沙江路 1517 弄",
- },
- {
-           date: "2016-05-01",
- name: "王小虎51",
-           address: "上海市普陀区金沙江路 1519 弄",
- },
- {
-           date: "2016-05-03",
- name: "王小虎52",
-           address: "上海市普陀区金沙江路 1516 弄",
- },
- ],
- };
- },
- methods: {
-       //获取表格数据,自行分页(slice)
- getTabelData() {
-         //allData为全部数据
- this.tableData = this.allData.slice(
- (this.page - 1) * this.size,
- this.page * this.size
- );
- this.total=this.allData.length
- },
-  
-  
-     //获取表格数据,自行分页(splice)
- getTabelData2() {
- let data=JSON.parse(JSON.stringify(this.allData))
- this.tableData = data.splice(
- (this.page - 1) * this.size,
- this.size
- );
- this.total=this.allData.length
- },
-     //page改变时的回调函数,参数为当前页码
- currentChange(val) {
- console.log("翻页,当前为第几页", val);
- this.page = val;
- this.getTabelData2();
- },
-     //size改变时回调的函数,参数为当前的size
- sizeChange(val) {
- console.log("改变每页多少条,当前一页多少条数据", val);
- this.size = val;
- this.page = 1; 
- this.getTabelData2();
- },
- },
- created() {
- this.getTabelData2();
- },
- };
- </script>
相关文章:
 
前端分页处理
页面中实现的分页效果,要么后端提供接口,每次点击下一页就调用接口,若不提供接口,分页得前端自己去截取。 方法一:slice方法 slice(参数1,参数2)方法是返回一个新的数组对象,左开右闭 参数1&…...
 
【C语言】位操作符的一些题目与技巧
初学者在学完位操作符之后,总是不能很好的掌握,因此这篇文章旨在巩固对位操作符的理解与使用。 有的题目可能会比较难以接受,但是看完一定会有收获 目录 位操作符:一些题目:不创建临时变量交换整数整数转换二进制中1的…...
 
爬虫逆向实战(二十二)--某恩数据电影票房
一、数据接口分析 主页地址:某恩数据 1、抓包 通过抓包可以发现数据接口是API/GetData.ashx 2、判断是否有加密参数 请求参数是否加密? 无请求头是否加密? 无响应是否加密? 通过查看“响应”模块可以发现,响应是…...
 
火山引擎发布自研视频编解码芯片
2023年8月22日,火山引擎视频云宣布其自研的视频编解码芯片已成功出片。经验证,该芯片的视频压缩效率相比行业主流硬件编码器可提升30%以上,未来将服务于抖音、西瓜视频等视频业务,并将通过火山引擎视频云开放给企业客户。 火山引…...
投递技术类简历的注意事项
简历修改的背景 作为程序员,随着工作年限的增加,要定期的去修改自己的简历中的工作项目,一方面可以促进自己复盘一下工作成果和个人成长,另外也能给自己换工作提供一个前置的便捷性。 注意事项 修改简历的时候有哪些需要注意的…...
 
每日一题——柱状图中最大的矩形
柱状图中最大的矩形 题目链接 用什么数据结构? 要得到柱状图中最大的矩形,我们就必须要知道对于每一个高度heights[i],他所能勾勒出的矩形最大是多少(即宽度最大是多少)。 而对应到图上我们可以知道,要知…...
 
Banana Pi推出基于龙芯2K1000LA处理器的信创工业控制开发平台
Banana Pi推出基于龙芯2K1000LA处理器的信创工业控制开发平台:BPI-5202信创工业控制开发平台 BPI-5202 龙芯2K1000LA 信创工业控制开发平台 1.1 工控机的应用场景 物联网的狂潮,既是一场众多的计算机软硬件厂家(也包括通讯方案和产品厂家&…...
 
springCloud整合Zookeeper的时候调用找不到服务
SpringCloud整合Zookeeper的时候调用找不到服务 首先,我们在注册中心注册了这个服务: 然后我们使用RestTemplate 调用的时候发现失败了:找不到这个服务: 找了很多资料发现这个必须要加上负载才行 BeanLoadBalanced //负载publi…...
 
【kubernetes】使用kubepshere部署中间件服务
KubeSphere部署中间件服务 入门使用KubeSphere部署单机版MySQL、Redis、RabbitMQ 记录一下搭建过程 (内容学习于尚硅谷云原生课程) 环境准备 VMware虚拟机k8s集群,一主两从,master也作为工作节点;KubeSphere k8skubesphere devops比较占用磁…...
如何从tabbar页面传数据
无论是百度小程序还是微信小程序,app.json中规定的tabbar页面是不支持传参的,例如: <navigator url../service/service?typeid6 openType"switchTab"> 服务项目 </navigator> 上面的navigater跳转有个属性&#…...
软考高级系统架构设计师系列论文七十四:基于构件的软件开发
软考高级系统架构设计师系列论文七十四:基于构件的软件开发 一、构件相关知识点二、摘要三、正文四、总结一、构件相关知识点 软考高级系统架构设计师系列之:面向构件的软件设计,构件平台与典型架构...
图为科技_边缘计算在智能安防领域的作用
边缘计算在智能安防领域发挥着重要的作用。智能安防系统通常需要处理大量的图像、视频和传感器数据,并对其进行实时分析和处理。边缘计算可以将计算和数据处理功能移动到离数据源更接近的地方,例如摄像头、传感器设备或安防终端。 以下是边缘计算在智能…...
 
Android 13 - Media框架(7)- NuPlayer::Source
Source 在播放器中起着拉流(Streaming)和解复用(demux)的作用,Source 设计的好坏直接影响到播放器的基础功能,我们这一节将会了解 NuPlayer 中的通用 Source(GenericSource)关注本地…...
 
MySql015——使用子查询
一、创建customers表 ######################## # Create customers table ######################## use study;CREATE TABLE customers (cust_id int NOT NULL AUTO_INCREMENT,cust_name char(50) NOT NULL ,cust_address char(50) NULL ,cust_city char…...
leetcode 355 设计推特
用链表存储用户发送的每一个推特,用堆获取最先的10条动态 class Twitter {Map<Integer,Set<Integer>> followMap;//规定最新的放到最后Map<Integer,Tweet> postMap;//优先队列(堆)PriorityQueue<Tweet> priorityQueue;int time…...
 
倒数 2 周|期待 2023 Google开发者大会
9 月 6-7 日,中国上海 前沿科技,新知同享 趣味体验,灵感齐聚 技术生态,多元共进 关注官网最新信息,敬请期待大会开幕 2023 Google 开发者大会官网 相信你一定记得,在今年 5 月的 Google I/O 大会上&am…...
代码随想录day57
516最长回文子序列 class Solution { public:int longestPalindromeSubseq(string s) {vector<vector<int>>dp(s.size(),vector<int>(s.size(),0));for(int i0;i<s.size();i)dp[i][i]1;for(int is.size()-1;i>0;i--){for(int ji1;j<s.size();j){if…...
 
YOLOv5、v8改进:CrissCrossAttention注意力机制
目录 1.简介 2. yolov5添加方法: 2.1common.py构建CrissCrossAttention模块 2.2yolo.py中注册 CrissCrossAttention模块 2.3修改yaml文件。 1.简介 这是ICCV2019的用于语义分割的论文,可以说和CVPR2019的DANet遥相呼应。 和DANet一样,…...
 
RabbitMQ特性介绍和使用案例
❤ 作者主页:李奕赫揍小邰的博客 ❀ 个人介绍:大家好,我是李奕赫!( ̄▽ ̄)~* 🍊 记得点赞、收藏、评论⭐️⭐️⭐️ 📣 认真学习!!!🎉🎉 文章目录 RabbitMQ特性…...
 
Ansible 使用 RHEL 系统角色
安装 RHEL 系统角色软件包,并创建符合以下条件的 playbook /home/greg/ansible/timesync.yml 在所有受管节点上运行 使用 timesync 角色 配置该角色,以使用当前有效的 NTP 提供商 配置该角色,以使用时间服务器 172.25.254.254 配置该角色&am…...
 
linux arm系统烧录
1、打开瑞芯微程序 2、按住linux arm 的 recover按键 插入电源 3、当瑞芯微检测到有设备 4、松开recover按键 5、选择升级固件 6、点击固件选择本地刷机的linux arm 镜像 7、点击升级 (忘了有没有这步了 估计有) 刷机程序 和 镜像 就不提供了。要刷的时…...
Matlab | matlab常用命令总结
常用命令 一、 基础操作与环境二、 矩阵与数组操作(核心)三、 绘图与可视化四、 编程与控制流五、 符号计算 (Symbolic Math Toolbox)六、 文件与数据 I/O七、 常用函数类别重要提示这是一份 MATLAB 常用命令和功能的总结,涵盖了基础操作、矩阵运算、绘图、编程和文件处理等…...
 
NLP学习路线图(二十三):长短期记忆网络(LSTM)
在自然语言处理(NLP)领域,我们时刻面临着处理序列数据的核心挑战。无论是理解句子的结构、分析文本的情感,还是实现语言的翻译,都需要模型能够捕捉词语之间依时序产生的复杂依赖关系。传统的神经网络结构在处理这种序列依赖时显得力不从心,而循环神经网络(RNN) 曾被视为…...
 
处理vxe-table 表尾数据是单独一个接口,表格tableData数据更新后,需要点击两下,表尾才是正确的
修改bug思路: 分别把 tabledata 和 表尾相关数据 console.log() 发现 更新数据先后顺序不对 settimeout延迟查询表格接口 ——测试可行 升级↑:async await 等接口返回后再开始下一个接口查询 ________________________________________________________…...
Mysql8 忘记密码重置,以及问题解决
1.使用免密登录 找到配置MySQL文件,我的文件路径是/etc/mysql/my.cnf,有的人的是/etc/mysql/mysql.cnf 在里最后加入 skip-grant-tables重启MySQL服务 service mysql restartShutting down MySQL… SUCCESS! Starting MySQL… SUCCESS! 重启成功 2.登…...
NPOI Excel用OLE对象的形式插入文件附件以及插入图片
static void Main(string[] args) {XlsWithObjData();Console.WriteLine("输出完成"); }static void XlsWithObjData() {// 创建工作簿和单元格,只有HSSFWorkbook,XSSFWorkbook不可以HSSFWorkbook workbook new HSSFWorkbook();HSSFSheet sheet (HSSFSheet)workboo…...
 
rm视觉学习1-自瞄部分
首先先感谢中南大学的开源,提供了很全面的思路,减少了很多基础性的开发研究 我看的阅读的是中南大学FYT战队开源视觉代码 链接:https://github.com/CSU-FYT-Vision/FYT2024_vision.git 1.框架: 代码框架结构:readme有…...
 
leetcode73-矩阵置零
leetcode 73 思路 记录 0 元素的位置:遍历整个矩阵,找出所有值为 0 的元素,并将它们的坐标记录在数组zeroPosition中置零操作:遍历记录的所有 0 元素位置,将每个位置对应的行和列的所有元素置为 0 具体步骤 初始化…...
raid存储技术
1. 存储技术概念 数据存储架构是对数据存储方式、存储设备及相关组件的组织和规划,涵盖存储系统的布局、数据存储策略等,它明确数据如何存储、管理与访问,为数据的安全、高效使用提供支撑。 由计算机中一组存储设备、控制部件和管理信息调度的…...
【Pandas】pandas DataFrame dropna
Pandas2.2 DataFrame Missing data handling 方法描述DataFrame.fillna([value, method, axis, …])用于填充 DataFrame 中的缺失值(NaN)DataFrame.backfill(*[, axis, inplace, …])用于**使用后向填充(即“下一个有效观测值”)…...
