zoukankan      html  css  js  c++  java
  • 简洁纯js分页

     做项目时偶尔有需求:数据一次性加载到页面同时还要实现分页,此时有两种方式一种是提交到当前页,这个里面会有一些变量需要置为hidden域,另外一种就是纯js分页。利用第一种方式效率不太高,存在多次访问数据库的问题,因而对于这种需要常常采用第二种方式。demo如下,实现思路:页面数据一次性全部加载完毕,js部分通过函数控制其是否显示达到分页的功能,有一个方法通过递归即可全部实现上一页、下一页、首页、尾页的功能,同时页面显示的分页点击部分也是由js内部innerHTML写入

     

    1、js部分(单独保存为page.js)--js中的加减参数需要根据实际情形决定,即table第一行开始到真正的数据行之间有几行,则加减参数就是几

     

    /**

     * 分页函数

     * pno--页数

     * psize--每页显示记录数

     * 分页部分是从真实数据行开始,因而存在加减某个常数,以确定真正的记录数

     * 纯js分页实质是数据行全部加载,通过是否显示属性完成分页功能

     **/

    function goPage(pno,psize){

    var itable = document.getElementById("idData");

    var num = itable.rows.length;//表格行数

    var totalPage = 0;//总页数

    var pageSize = psize;//每页显示行数

    if((num-1)/pageSize > parseInt((num-1)/pageSize)){   

         totalPage=parseInt((num-1)/pageSize)+1;   

        }else{   

        totalPage=parseInt((num-1)/pageSize);   

        }   

    var currentPage = pno;//当前页数

    var startRow = (currentPage - 1) * pageSize+1;//开始显示的行   

        var endRow = currentPage * pageSize+1;//结束显示的行   

        endRow = (endRow > num)? num : endRow;

    //前三行始终显示

    for(i=0;i<1;i++){

    var irow = itable.rows[i];

    irow.style.display = "block";

    }

    for(var i=1;i<num;i++){

    var irow = itable.rows[i];

    if(i>=startRow&&i<endRow){

    irow.style.display = "block";

    }else{

    irow.style.display = "none";

    }

    }

    var pageEnd = document.getElementById("pageEnd");

    var tempStr = "共"+(num-1)+"条记录 分"+totalPage+"页 当前第"+currentPage+"页";

    if(currentPage>1){

    tempStr += "<a href=\"#\" onClick=\"goPage("+(currentPage-1)+","+psize+")\">上一页</a>"

    }else{

    tempStr += "上一页";

    }

    if(currentPage<totalPage){

    tempStr += "<a href=\"#\" onClick=\"goPage("+(currentPage+1)+","+psize+")\">下一页</a>";

    }else{

    tempStr += "下一页";

    }

    if(currentPage>1){

    tempStr += "<a href=\"#\" onClick=\"goPage("+(1)+","+psize+")\">首页</a>";

    }else{

    tempStr += "首页";

    }

    if(currentPage<totalPage){

    tempStr += "<a href=\"#\" onClick=\"goPage("+(totalPage)+","+psize+")\">尾页</a>";

    }else{

    tempStr += "尾页";

    }

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

    }

     

     

    2、html部分

     

    <html>

    <head>

    <script type="text/javascript" src="page.js"></script>

     

    </head>

    <body onLoad="goPage(1,10);">

    <table id="idData" width="70%">

    <tr>

    <td>姓名</td>

    <td>年龄</td>

    <td>性别</td>

    <td>户籍</td>

    </tr>

    <tr>

    <td>刘金钟</td>

    <td>25</td>

    <td>男</td>

    <td>山西吕梁</td>

    </tr>

    <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>liujinzhong</td>

    <td>25</td>

    <td>男</td>

    <td>山西吕梁</td>

    </tr>

    <tr>

    <td>liujinzhong</td>

    <td>25</td>

    <td>男</td>

    <td>山西吕梁</td>

    </tr>

    <tr>

    <td>liujinzhong</td>

    <td>25</td>

    <td>男</td>

    <td>山西吕梁</td>

    </tr>

    <tr>

    <td>liujinzhong</td>

    <td>25</td>

    <td>男</td>

    <td>山西吕梁</td>

    </tr>

    <tr>

    <td>liujinzhong</td>

    <td>25</td>

    <td>男</td>

    <td>山西吕梁</td>

    </tr>

    </table>

    <table width="60%" align="right">

    <tr>

    <td>

    <div id="barcon" name="barcon"></div>

    </td>

    </td>

    </table>

    </body>

     

    </html>

  • 相关阅读:
    0~n-1中缺失的数字
    仅仅反转字母
    字符串相加
    反转字符串&反转字符串中的元音字母
    python OrderedDict类&LRU缓存机制练习题
    协程greenlet、gevent、猴子补丁
    生产者与消费者(两个线程之间的通信---队列实现)
    jquery的on()
    Python之内置类型
    Python之比较运算符
  • 原文地址:https://www.cnblogs.com/liufei88866/p/1914457.html
Copyright © 2011-2022 走看看