js实现分页
大家在展示数据的时候难免会用到表格,而分页的存在会使表格看起来更简洁。
<table class="table table-hover"> <thead> <tr> <th>日期</th> <th>小时</th> <th>温度</th> </tr> </table> <table class="table table-hover table-striped" id="table_result"> <tbody id="table_body_result"> <tr> <td>2017-01-10</td> <td>20</td> <td>20</td> </tr> <tr> <td>2017-01-10</td> <td>20</td> <td>20</td> </tr> <tr> <td>2017-01-10</td> <td>20</td> <td>20</td> </tr> <!--中间省略多行数据--> </tbody> </table> <div id="barcon" name="barcon"></div>//空的div用来放分页后的表格
下面是js分页的代码
goPage(1,15); function goPage(pno, psize) { var itable = document.getElementById("table_result");//通过ID找到表格 var num = itable.rows.length;//表格所有行数(所有记录数) var totalPage = 0;//总页数 var pageSize = psize;//每页显示行数 //总共分几页 if (num / pageSize > parseInt(num / pageSize)) { totalPage = parseInt(num / pageSize) + 1; } else { totalPage = parseInt(num / pageSize); } var currentPage = pno;//当前页数 var startRow = (currentPage - 1) * pageSize + 1;//开始显示的行 1 var endRow = currentPage * pageSize;//结束显示的行 15 endRow = (endRow > num) ? num : endRow; //遍历显示数据实现分页 for (var i = 1; i < (num + 1); i++) { var irow = itable.rows[i - 1]; if (i >= startRow && i <= endRow) { irow.style.display = "block"; } else { irow.style.display = "none"; } } var tempStr = ""; if (currentPage > 1) { tempStr += "<a href=\"#\" onClick=\"goPage(" + (currentPage - 1) + "," + psize + ")\"><上一页 </a>" for (var j = 1; j <= totalPage; j++) { tempStr += "<a href=\"#\" onClick=\"goPage(" + j + "," + psize + ")\">" + j + " </a>" } } else { tempStr += "<上一页 "; for (var j = 1; j <= totalPage; j++) { tempStr += "<a href=\"#\" onClick=\"goPage(" + j + "," + psize + ")\">" + j + " </a>" } } if (currentPage < totalPage) { tempStr += "<a href=\"#\" onClick=\"goPage(" + (currentPage + 1) + "," + psize + ")\">下一页> </a>"; for (var j = 1; j <= totalPage; j++) { } } else { tempStr += " 下一页> "; for (var j = 1; j <= totalPage; j++) { } } document.getElementById("barcon").innerHTML = tempStr; }
效果图 其一
效果图 其二
下面对代码进行解读
goPage(1,15);//指的是当前页为第一页,15条数据为一页
然后计算出一共分为几页
var totalPage = 0;//总页数 var pageSize = psize;//每页显示行数 if (num / pageSize > parseInt(num / pageSize)) {//假设有20条数据,15条数据页 totalPage = parseInt(num / pageSize) + 1;//1.333>1 ,所以分为两页 } else { totalPage = parseInt(num / pageSize);//若有45条数据,则分为3页 }
计算开始显示的行数,和最后显示的行数
var currentPage = pno;//当前页数 var startRow = (currentPage - 1) * pageSize + 1;//开始显示的行 1 var endRow = currentPage * pageSize;//结束显示的行 15 endRow = (endRow > num) ? num : endRow;
遍历显示数据实现分页
for (var i = 1; i < (num + 1); i++) { var irow = itable.rows[i - 1]; if (i >= startRow && i <= endRow) { irow.style.display = "block";//当前页的数据 } else { irow.style.display = "none";//非当前页的数据 } }
实现最下方的显示,第几页,上一页,下一页
当前页为第一页时,上一页没有点击事件
当前页为最后一页时,下一页没有点击事件
否则,上一页和下一页均可使用,点击某一页会跳转到那一页
if (currentPage > 1) { tempStr += "<a href=\"#\" onClick=\"goPage(" + (currentPage - 1) + "," + psize + ")\"><上一页 </a>" for (var j = 1; j <= totalPage; j++) { tempStr += "<a href=\"#\" onClick=\"goPage(" + j + "," + psize + ")\">" + j + " </a>" } } else { tempStr += "<上一页 "; for (var j = 1; j <= totalPage; j++) { tempStr += "<a href=\"#\" onClick=\"goPage(" + j + "," + psize + ")\">" + j + " </a>" } } if (currentPage < totalPage) { tempStr += "<a href=\"#\" onClick=\"goPage(" + (currentPage + 1) + "," + psize + ")\">下一页> </a>"; for (var j = 1; j <= totalPage; j++) { } } else { tempStr += " 下一页> "; for (var j = 1; j <= totalPage; j++) { } }
屏幕快照 2017-05-09 15.48.00.png
到此,分页效果已经实现了。
原文地址:https://www.jianshu.com/p/92a74a3a0e60
相关推荐
-
前端应该知道的Web Components javascript/jquery
2019-7-2
-
JS中的基本类型和引用类型 javascript/jquery
2020-5-28
-
GitHub使用SSHkey进行连接 javascript/jquery
2019-8-20
-
1024 巨献!!一文看尽过去一年前端领域的那些好文(700 篇大汇总) javascript/jquery
2019-10-28
-
首页右下角意见反馈弹框+Notice轮播 javascript/jquery
2020-6-16
-
Ajax总结篇 javascript/jquery
2017-12-12
-
基于 HTML5 WebGL 的 3D 服务器与客户端的通信 javascript/jquery
2020-6-11
-
前端解决第三方图片防盗链的办法 – html referrer 访问图片资源403问题 javascript/jquery
2019-6-14
-
vue中v-model的应用 javascript/jquery
2020-6-9
-
封装框架的实践 javascript/jquery
2018-12-9