javascript 封装分页

最近自己做了一个后台,想把分页通过js给封装起来

于是乎就有了下面的代码

此代码,算是一个半成品,还需完善,思路还是可以借鉴的

 page方法传入3个参数

1、total总条数

2、page当前页码

3、seVal当前也显示的总数

page: function (total, page,seVal) {
        var pageHtml = '<div class="col-lg-4 col-md-4 col-sm-12">';
        pageHtml += '<div class="dataTables_info" id="datatable_info"></div></div>';
        pageHtml += '<div class="col-lg-8 col-md-8 col-sm-12">';
        pageHtml += '<div class="dataTables_paginate paging_bs_full" id="datatable_paginate">';
        pageHtml += '<div class="page-select"> 每页记录 <select id="spage"><option value="10">10</option>';
        pageHtml += '<option value="30">30</option><option value="50">50</option>';
        pageHtml += '<option value="100">100</option><option value="500">500</option>';
        pageHtml += '<option value="1000">1000</option></select></div>';
        pageHtml += '<ul class="pagination">';
        pageHtml += ' </ul>';
        pageHtml += '</div>';
        pageHtml += '</div>';
        pageHtml += '';
        $("#pageRow").html(pageHtml);
        //1、下拉选择 
        //2、根据分页显示索引值
        var starSum = (page - 1) * seVal == 0 ? 1 : (page - 1) * seVal;
        var rowTip = '检索到 ' + total + ' 条记录 显示第 ' + starSum + ' 条 - ' + ((page * seVal) > total ? total : (page * seVal)) + '';
        $("#datatable_info").html(rowTip);
        //3、计算总页数
        var pageCount = Math.ceil((total * 1.0) / seVal);
        var strPage = '';
        //4、判断首页
        if (page == 1) {
            strPage += '<li class="disabled"><a tabindex="0" class="first" id="datatable_first">首页</a></li>';
            strPage += '<li class="disabled"><a tabindex="0" class="previous" id="datatable_previous">上一页</a></li>';
        } else {
            strPage += '<li><a tabindex="0" data-page="1" class="paginate_button first" id="datatable_first">首页</a></li>';
            strPage += '<li class=""><a data-page="' + (parseInt(page) - 1) + '" tabindex="0" class="paginate_button previous" id="datatable_previous">上一页</a></li>';
        }
        //5、如果总数小于制定数,循环
        if (pageCount < 6) {
            for (var i = 1; i < pageCount + 1; i++) {
                strPage += '<li class="' + (i == page ? 'disabled' : '') + '"><a data-page="' + i + '" class="paginate_button" tabindex="0">' + i + '</a></li>';
            }
        } else {
            var maxfeye = parseInt(page) + 3;
            var minfeye = parseInt(page) - 2;
            if (page < 6) {
                maxfeye = 6;
                minfeye = 1;
            }
            if (maxfeye > pageCount) {
                minfeye = pageCount-4;
                maxfeye = pageCount;
            }
            
            for (var f = minfeye; f < maxfeye+1; f++) {
                strPage += '<li class="' + (f == page ? 'disabled' : '') + '"><a data-page="' + f + '" class="paginate_button" tabindex="0">' + f + '</a></li>';
            }
        }
        //6、尾页
        if (page == pageCount) {
            strPage += '<li class="disabled"><a tabindex="0" class="next" id="datatable_next">下一页</a></li>';
            strPage += '<li class="disabled"><a tabindex="0" class="last" id="datatable_last">尾页</a></li>';
        } else {
            strPage += '<li class=""><a tabindex="0" data-page="' + (parseInt(page) + 1) + '" class="paginate_button next" id="datatable_next">下一页</a></li>';
            strPage += '<li class=""><a tabindex="0" data-page="' + pageCount + '" class="paginate_button last" id="datatable_last">尾页</a></li>';
        }
        $(".pagination").html(strPage);
        //7、分页页码点击事件
        $("a.paginate_button").on('click', function () {
            fyt.initList($(this).attr("data-page"), $("#spage").val());
        });
        //8、每页记录下拉事件
        $("#spage").on('change', function () {
            fyt.initList(1,$(this).val());
        });
        //9、给下拉框赋值
        $("#spage").val(seVal);
    }
View Code

 

最终显示截图,上图

 

 

已完成,如果谁有更好的方法,或者更好优化的地方,可以交流交流

86594082 屌丝聚集之地  你懂得

posted @ 2015-03-19 10:57  Jason.裕哥  阅读(450)  评论(0编辑  收藏  举报