纯js实现分页

原理:所有数据已加载好,js通过遍历部分显示,实现分页效果

html代码

<html>
<head>
    <meta charset=‘utf-8‘>
<script type="text/javascript" src="page.js"></script>

 <style type="text/css">
    #idData {color: red;border: solid;text-align: center;}
    a{text-decoration: none;}
 </style>
</head>
<body onLoad="goPage(1,10);">
    <table id="idData" width="70%">
        <tr><td>liujinzhong1</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong2</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong3</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong4</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong5</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong6</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong7</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong8</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong9</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong10</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong11</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong12</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong13</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong14</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong15</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong16</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong17</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong18</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong19</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong20</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong21</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong22</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong23</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong24</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong25</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong26</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong27</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong28</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong29</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong30</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong31</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong32</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong33</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong34</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong35</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong36</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong37</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong38</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong39</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
        <tr><td>liujinzhong40</td><td>25</td><td>男</td><td>山西吕梁</td></tr>
    </table>
    <table width="60%" align="right">
        <tr><td><div id="barcon" name="barcon"></div></td></tr>
    </table>
</body>
</html>

js实现分页

/**
 * 分页函数
 * pno--页数
 * psize--每页显示记录数
 * 分页部分是从真实数据行开始,因而存在加减某个常数,以确定真正的记录数
 * 纯js分页实质是数据行全部加载,通过是否显示属性完成分页功能
 **/
function goPage(pno,psize){
    var itable = document.getElementById("idData");
    var num = itable.rows.length;//表格所有行数(所有记录数)
    console.log(num);
    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;//开始显示的行  31
       var endRow = currentPage * pageSize;//结束显示的行   40
       endRow = (endRow > num)? num : endRow;    40
       console.log(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 pageEnd = document.getElementById("pageEnd");
    var tempStr = "共"+num+"条记录 分"+totalPage+"页 当前第"+currentPage+"页";
    if(currentPage>1){
        tempStr += "<a href=\"#\" onClick=\"goPage("+(1)+","+psize+")\">首页</a>";
        tempStr += "<a href=\"#\" onClick=\"goPage("+(currentPage-1)+","+psize+")\"><上一页</a>"
    }else{
        tempStr += "首页";
        tempStr += "<上一页";
    }

    if(currentPage<totalPage){
        tempStr += "<a href=\"#\" onClick=\"goPage("+(currentPage+1)+","+psize+")\">下一页></a>";
        tempStr += "<a href=\"#\" onClick=\"goPage("+(totalPage)+","+psize+")\">尾页</a>";
    }else{
        tempStr += "下一页>";
        tempStr += "尾页";
    }

    document.getElementById("barcon").innerHTML = tempStr;

}

效果

时间: 2024-08-27 15:05:25

纯js实现分页的相关文章

纯js手动分页

昨天让做个页面,后台提供所有数据,没有做好分页,需要前端js手动分页. 我参考了 http://www.cnblogs.com/jiechn/p/4095029.html 做了些许改动让分页效果更加完善. 最终效果图 js代码 /** * 分页函数 * pno--页数 * psize--每页显示记录数 * 分页部分是从真实数据行开始,因而存在加减某个常数,以确定真正的记录数 * 纯js分页实质是数据行全部加载,通过是否显示属性完成分页功能 **/ function goPage(pno){ va

jQuery+AJAX实现纯js分页功能

使用jQuery的AJAX技术,在bootstrap的框架下搭建的纯js分页 bootstrap作为Twitter推的一款前端框架,效果个人还是觉得很不错的.这次只是拿来作为网页元素的css样式表使用,比较省力,效果也会比自己做要漂亮多了. 使用数据为单独的json文件data.json [plain] view plain copy [ { "name": "bootstrap-table", "stargazers_count": "

使用纯js写的一个分页

上图晒效果: 网上确实有很多分页的插件以及开源代码,单本是一个后台开发猿,前台css等样式还驾驭不住,所以就开始自己去写了.其实这个分页原理很简单,就是用ajax往后台传值(当前页码),后台使用limit进行分页. 因为这是我自己第一次动手用js写分页,写的应该也不是很完美,有些公共的没有抽取出来,但是用起来还是可以的,这块代码是可以把它当做公共的分页去处理的,我就是用 这块代码写了两个稍微不同一些的分页!公共的代码抽取的也差不多,主要就是ajax后台以及返回的值不同而已,只要把总页码的值获取到

纯js实现html转pdf

项目开发中遇到了一个变态需求,需要把一整个页面导出为pdf格式,而且要保留页面上的所有的表格.svg图片和样式.简而言之,就是希望像截图一样,把整个页面截下来,然后保存成pdf.咋不上天呢--查了一下,能够实现html转pdf的方法还是挺多的,大概有以下几种:1.大部分浏览器就有这个功能.然而我们客户要的可不是这个,人家要的是能够在系统中主动触发的导出为pdf功能,所以这种方案pass.2.利用第三方工具.我找到了一种利用wkhtmltopdf这种工具来导出的方案,自己在我们的项目中试了一下,效

Highcharts纯js图表库,以后可以跟客户说,你跟阿里云ECS用的图表库是同款

Highcharts是一款纯javascript编写的图表库,能够很简便的在Web网站或Web应用中添加交互性的图表,Highcharts目前支持直线图.曲线图.面积图.柱状图.饼图.散点图等多达18种不同类型的图表,可以满足常用的Web图表需求 ! 近来维护我的阿里云服务器,进入后台偶然发现阿里云管理后台数据图表用的也是Highcharts,刚好正需要WEB端展示数据的东西,研究哈… Highcharts官网:http://www.highcharts.com Highcharts中文站:ht

单篇文章JS模拟分页

废话部分 前两天做了一个前台分页插件,支持ajax读取数据绑定前台 和 url带页码参数跳转两种方式.于是稍加改动,做了一个单篇文章js模拟分页的代码,为什么说是模拟分页呢?因为在服务器响应HTML请求的时候,就已经把全文回传给客户端了,只是我们通过js的方式,把全文隐藏,每次翻页至显示出我们需要的那一部分,而不是真正的按需要去发出HTML请求.所以,在做这个插件的时候去掉了ajax请求的功能及其附带参数,去掉了pageSize参数(恒等于1).这里就不讨论具体的技术细节了和上一篇的分页计算原理

纯js页面跳转整理

js方式的页面跳转1.window.location.href方式    <script language="javascript" type="text/javascript">           window.location.href="http://updn.cn";     </script>2.window.navigate方式跳转   <script language="javascript

纯js制作的弹球游戏

纯js的弹球游戏,撞壁自动返回,按钮放置暂停移动,移开开始移动 1 <!-- 2 author:zhangjie 3 date :2016-7-23 4 --> 5 <!DOCTYPE html> 6 <html> 7 <head> 8 <title></title> 9 <meta charset="UTF-8"> 10 <script type='text/javascript'> 11

[分享黑科技]纯js突破localstorage存储上线,远程抓取图片,并转码base64保存本地,最终实现整个网站所有静态资源离线到用户手机效果却不依赖浏览器的缓存机制,单页应用最新黑科技

好久没有写博客了,想到2年前答应要放出源代码的也没放出来,最近终于有空先把纯js实现无限空间大小的本地存储的功能开源了,项目地址https://github.com/xueduany/localstore,demo见http://xueduany.github.io/localstore/,下面给大家简单说说大概原理,具体细节和异常处理后面有机会在单独说 先说下突破本地localStorage的原理,官方原话是这么说的http://www.w3.org/TR/2013/PR-webstorage