jquery分页组件(每页显示多少条)

/**
 *  功能说明:jPager 分页插件
 *  参数说明:pages:[] 分页的控件个数 @id:显示分页的div ID,@showSelectPage: 是否显示当前分页的条目过滤下拉框
 *  @currentpage 当前第几页
 *  @pagesize   type:number    每页显示多少条目
 *  @total       type:number   总条数
 *  @totalpage   type:number  总页码数
 * */

(function ($) {
    ‘use strict‘;

    $.jPager = function (option) {

        if (!option || option.totalpage == 0) {

            for (var i = 0; i < option.pages.length; i++){
                $(‘#‘+ option.pages[i].id).empty();
            }
            return;
        }

        var limitNumber = [20, 30, 50];

        var defaultOption = {
            pages: [{
                id: ‘‘,
                showSelectPage: true
            }],
            currentpage: 1, //当前页
            pagesize: 20, //一页显示数量
            total:1, //条数
            totalpage: 1 //总页码
        };

        var pageObj = $.extend(defaultOption, option);

        if (pageObj.pages.length == 0) {
            return;
        }

        for (var i = 0; i < pageObj.pages.length; i++) {
            var obj = pageObj.pages[i];
            var _btnId = obj.id;
            var _isShowSelect = obj.showSelectPage;
            var tpl = ‘<div class="pager-left">总共&nbsp;‘+ pageObj.total +‘&nbsp;条</div></div><div class="pager-center"><span class="pager">‘;
            if (_isShowSelect) {
                tpl += ‘<span class="count" date-val="‘+ pageObj.pagesize +‘">‘+ pageObj.pagesize +‘</span>‘;
                tpl += ‘<span class="pageCount">‘;
                tpl += ‘<dl><dt class="open-dt" role-page="role-page" data-val="‘+ pageObj.pagesize +‘">‘;
                tpl += ‘<i class="icon-yt-menu-list"></i></dt>‘;
                tpl += ‘<dd style="display:none" data-val="‘+limitNumber[0]+‘">‘+limitNumber[0]+‘&nbsp;<i class="fa fa-check hide"></i></dd>‘;
                tpl += ‘<dd style="display:none" data-val="‘+limitNumber[1]+‘">‘+limitNumber[1]+‘&nbsp;<i class="fa fa-check hide"></i></dd>‘;
                tpl += ‘<dd style="display:none" data-val="‘+limitNumber[2]+‘">‘+limitNumber[2]+‘&nbsp;<i class="fa fa-check hide"></i></dd>‘;
                tpl += ‘</dl></span>‘;
            }

            tpl += ‘<span class="firstPage hide"><i class="fa fa-angle-double-left"></i></span><span class="pageContainer">‘;

            var _pages = [];
            if (pageObj.totalpage > 5) {

                if (pageObj.currentpage <= 3) {
                    _pages = [1, 2, 3, 4, 5];
                } else if (pageObj.currentpage > 3 && (pageObj.totalpage - pageObj.currentpage >= 2)){
                    _pages[0] = pageObj.currentpage - 2;
                    _pages[1] = pageObj.currentpage - 1;
                    _pages[2] = pageObj.currentpage;
                    _pages[3] = pageObj.currentpage + 1;
                    _pages[4] = pageObj.currentpage + 2;
                }else if (pageObj.currentpage > 3 && (pageObj.totalpage - pageObj.currentpage == 0)){
                    _pages[0] = pageObj.currentpage - 4;
                    _pages[1] = pageObj.currentpage - 3;
                    _pages[2] = pageObj.currentpage - 2;
                    _pages[3] = pageObj.currentpage - 1;
                    _pages[4] = pageObj.currentpage;
                }else if (pageObj.currentpage > 3 && (pageObj.totalpage - pageObj.currentpage == 1)) {
                    _pages[0] = pageObj.currentpage - 3;
                    _pages[1] = pageObj.currentpage - 2;
                    _pages[2] = pageObj.currentpage - 1;
                    _pages[3] = pageObj.currentpage;
                    _pages[4] = pageObj.currentpage + 1;
                }

            } else {
                for (var j = 0; j < pageObj.totalpage; j++ ) {
                    _pages[j] = j + 1;
                }
            }

            for (var k = 0; k < _pages.length; k++ ) {
                tpl += ‘<span class="page" data-page="page‘+ _pages[k] +‘">‘+ _pages[k] +‘</span>‘;
            }

            tpl += ‘</span><span class="lastPage hide"><i class="fa fa-angle-double-right"></i></span></span></div>‘;

            var _totalTpl = ‘<div class="pull-left">‘+ pageObj.total +‘&nbsp;<span>条数据</span></div>‘;
            var _select = ‘<select id="goToPage">‘;
            var _sOption = ‘‘;
            for(var p = 0; p < pageObj.totalpage; p++) {
                _sOption += ‘<option value="‘+ (p + 1) +‘">‘+ (p + 1) +‘</option>‘;
            }

            _select += _sOption + ‘</select>‘;
            var _gogoPage = ‘<div class="pager-right">跳转至‘+ _select +‘页</div>‘;
            if (obj.showTotal) {
                tpl = _totalTpl + tpl;
            }
            $(‘#‘+_btnId).html(tpl+_gogoPage);
            $(‘#goToPage‘).val(pageObj.currentpage);

            //设置上一页 、下一页 是否可见
            if (pageObj.currentpage == 1) {
                if (pageObj.totalpage >1) {
                    $(‘.lastPage‘).removeClass(‘hide‘);
                }
            }else if (pageObj.currentpage > 1) {
                if (pageObj.currentpage == pageObj.totalpage) {
                    $(‘.firstPage‘).removeClass(‘hide‘);
                }else{
                    $(‘.firstPage‘).removeClass(‘hide‘);
                    $(‘.lastPage‘).removeClass(‘hide‘);
                }
            }

            //切换页码
            $(‘#goToPage‘).unbind().bind(‘change‘, function () {
                var _val = $(this).val();
                var page = {
//                    limit: $(‘.pager .count:eq(0)‘).text().trim(),
                    page: _val
                }

                obj.callback(page);
            });

            //点击页码数量
            $(‘.pageCount dd‘).click(function () {

                var _hasClass = $(this).children(‘i‘).hasClass(‘hide‘);
                if (!_hasClass) {
                    return;
                }

                var _text = $(this).text();
                var _val = $(this).attr(‘data-val‘);
                $(‘.pager .count‘).text(_text);
                $(this).siblings(‘dd‘).children(‘i‘).addClass(‘hide‘);
                $(this).children(‘i‘).removeClass(‘hide‘);
                if($(‘#limit‘)){
                    $(‘#ipt_limit‘).val(_text);
                }

                var page = {
                    limit: $(‘.pager .count:eq(0)‘).text().trim(),
                    page: 1
                }

                $(‘.pageCount dd‘).slideUp(10, function () {
                    $(this).siblings(‘dt‘).attr(‘style‘, ‘‘).attr(‘data-val‘, _val);
                    $(this).siblings(‘dd‘).children(‘i‘).addClass(‘hide‘);
                });
                obj.callback(page);
            });

            //点击页码
            $(‘span[data-page]‘).click(function () {
                var _hasClass = $(this).hasClass(‘active‘);

                if (_hasClass) {
                    return;
                }

                var _page = $(this).attr(‘data-page‘);
                $(‘span[data-page]‘).removeClass(‘active‘);
                //$(this).addClass(‘active‘);
                $(‘span[data-page="‘+ _page +‘"]‘).addClass(‘active‘);
                if($(‘#ipt_page‘)){
                    $(‘#ipt_page‘).val(_page);
                }

                var page = {
                    page: $(‘.pager:eq(0) .active‘).text().trim(),
                    limit: $(‘.pager .count:eq(0)‘).text().trim()
                }
                obj.callback(page);
            });

            //点击上一页
            $(‘#‘+_btnId +‘ span .firstPage i‘).bind(‘click‘, function () {
                var currentPage = parseInt($(‘.pager:eq(0) .active‘).text().trim());
                if (currentPage == 1) {
                    $(‘.firstPage‘).addClass(‘hide‘);
                    return;
                }
                var page = {
                    page: 1,
                    limit: $(‘.pager .count:eq(0)‘).text().trim()
                }
                obj.callback(page);
            });

            //点击下一页
            $(‘#‘+_btnId +‘ span .lastPage i‘).click(function () {
                var currentPage = parseInt($(‘.pager:eq(0) .active‘).text().trim());
                if (currentPage == pageObj.totalpage) {
                    $(‘.lastPage‘).addClass(‘hide‘);
                    return;
                }
                var page = {
                    page: pageObj.totalpage,
                    limit: $(‘.pager .count:eq(0)‘).text().trim()
                }
                obj.callback(page);
            });
        }

        //初始化,选中当前页码
        $(‘span[data-page]‘).removeClass(‘active‘);
        $(‘span[data-page="page‘+ pageObj.currentpage +‘"]‘).addClass(‘active‘);

        /* 切换每页条数  */
        $(‘.pageCount dt‘).click(function() {

            var _val = $(this).attr(‘data-val‘);
            $(this).siblings(‘dd[data-val="‘+_val+‘"]‘).children(‘i‘).removeClass(‘hide‘);

            $(‘dd‘).slideUp(10, function() {
                $(‘.select-has-border‘).removeClass(‘select-has-border-open‘).children(‘dd‘).css(‘display‘, ‘none‘);
                $(‘.campaign-query‘).css(‘border-radius‘, ‘5px‘);
                $(‘.cp-select‘).removeClass(‘cp_select_open‘);
            });
            var _isShow  = $(this).siblings(‘dd‘).css(‘display‘) == ‘none‘ ? false : true;
            if (_isShow) {
                $(this).siblings(‘dd‘).hide();//.removeClass(‘page-Open‘).addClass(‘page-Close‘)
                var _css = {
                    ‘borderTop‘: ‘0px solid #ccc‘,
                    ‘border-top-right-radius‘: ‘0px‘,
                    ‘border-top-left-radius‘: ‘0px‘,
                    ‘backgroundColor‘: ‘white‘,
                    ‘color‘: ‘‘
                };
                $(this).css(_css);
            } else {
                $(this).siblings(‘dd‘).slideDown(10);//.removeClass(‘page-Close‘).addClass(‘page-Open‘)
                var _css = {
                    ‘border-top-right-radius‘: ‘5px‘,
                    ‘border-top-left-radius‘: ‘5px‘,
                    ‘backgroundColor‘: ‘#414C59‘,
                    ‘color‘: ‘white‘
                };
                $(this).css(_css);
            }
        });

    };
})(jQuery);
/*  分页  */
.pager{
    height: 30px;
    line-height: 30px;
    padding: 0;
    margin-top: 0;
    margin-left: 70px;
    display: inline-block;
}

.pager{
    float:left;
}

.pager .pageCount{
    float:left;
    width:60px;
    height: 30;
    line-height: 30px;
    text-align: left;
    margin-left: -5px;
    text-indent: 5px;
}

.pager .count{
    padding-top:3px;
    float:left;
    cursor:default;
}

.pager .pageCount dl{
    margin: 0;
    padding: 0;
    width: 60px;
}

.pager .pageCount dt>i:first-child{
    vertical-align:bottom;
    margin-top: 3px;
}

.pager .pageCount dd{
    background-color: #414C59;
    height: 24px;
    width:60px;
    line-height: 24px;
    text-align: left;
    text-indent: 5px;
    color: white;
    border:none;
}

.pager .pageCount dd:last-child{
    border-bottom-right-radius: 5px;
    border-bottom-left-radius: 5px;
}

.pager .pageCount dd:hover{
    background-color: #333E4D;
}

.pager-left{
    float:left;
    width: 100px;
}

.pager-center{
    float:left;
    width: 340px;
}

.pager-right{
    float: left;
    width: 160px;
}

#goToPage{
    width:50px;
    margin-left: 5px;
    margin-right: 5px;
}

.pager dt:hover{
    color:#2AC3FA;
}

.pager .firstPage{
    margin-left: 20px;
}

.pager .firstPage>i{
    margin-top: 5px;
}

.pager .page{
    margin-left: 5px;
}

.pager .lastPage{
    margin-left: 10px;
}

.pager .lastPage>i{
    margin-top: 5px;
}

.pager i.little{
    font-size:10px;
    vertical-align: top;
    margin-top: 5px;
    margin-left: 2px
}

.pager span{
    cursor: pointer;
    border:1px solid transparent;
}

.pager .page{
    padding-left: 3px;
    padding-right: 5px;
    padding-top: 2px;
    padding-bottom: 2px;
    border-radius: 5px;
}

.pager span.active{
    background-color: #2AC3FA;
    color:white;
    padding-left: 5px;
    padding-right: 5px;
    padding-top: 1px;
    padding-bottom: 2px;
    border-radius: 5px;
}

.pager span.page:hover{
    background-color: white;
    border:1px solid #2AC3FA;
    color:#2AC3FA;
}

.pager .lastPage:hover, .pager .firstPage:hover{
    color:#2AC3FA;
}

.pager .open{
    color:#ffffff;
    background-color: #414C59;
}

.pager span{
    display:inline-block;
    height: 24px;
    line-height: 20px;
    margin-left: 2px;
    float: left;
}

.pager .pageContainer{
    display: inline-block;
    min-width: 26px;
    width: auto;
    height: 30px;
    line-height: 30px;
    overflow:hidden;
}

需要的参数:

使用方法:

//分页控件
                var option = {
                    pages: [{
                        id: ‘pageIndex‘,
                        showSelectPage: false,
                        callback: function (option) {
                            //点击页码回调函数
                            //goPage(option);
                            var param = {
                                ‘grade_id‘: $(‘#addGrade‘).val(),
                                ‘class_id‘: $(‘#addClass‘).val(),
                                ‘start_date‘:  $(‘#startTime‘).val(),
                                ‘end_date‘: $(‘#endTime‘).val(),
                                ‘status‘: $(‘#foodStatus‘).val()
                            };

                            param = $.extend(param, option);
                            renderSyllabusIndex(param); //点击页码的回调函数
                        }
                    }],
                    pagesize: _data.pagesize,
                    total: _data.total,
                    currentpage: _data.currentpage,
                    totalpage: _data.totalpage
                };

                $.jPager(option);

效果:

时间: 2025-01-17 04:21:47

jquery分页组件(每页显示多少条)的相关文章

Django中使用JS通过DataTable实现表格前端分页,每页显示页数,搜索等功能

版本: django:2.1.7 python:3.7 Django架构中自带了后端分页的技术,通过Paginator进行分页,前端点击按钮提交后台进行页面切换. 优缺点:后端分页对于数据量大的场景有其优势,但页面切换比较慢. 后端分页python3代码如下: paginator = Paginator(stat_list, numtmp) try: flight_stats = paginator.page(1) except PageNotAnInteger: flight_stats =

RDLC报表:每页显示N条记录

摘要: 提供一种方案,使分页浏览的报表每页显示固定条数记录,最后一页记录条数不足的,用空行补齐. 示例: 记录共7条,每页显示5条记录: 下载代码(vs2008,需要安装AdventureWorks数据库) 下载代码(vs2008,不需要数据库支持) 下载代码(仅rdlc报表定义文件) 原理: 由于表的分组包含“在起始处分页”和”在结束处分页”的功能,所以我们考虑先将数据分成若干个记录条数为N的组, 再启用“在结束处分页”的功能. 那么,如何分组呢?考虑记录的下标为 0,1,2,3... 的自然

百度-设置-搜索设置-每页显示50条-保存设置-打印alert信息-accept确定

一.场景: 代码: #coding:utf-8from selenium import webdriverfrom selenium.webdriver.common.action_chains import ActionChainsfrom selenium.webdriver.support.select import Selectimport timedriver=webdriver.Chrome()#打开百度首页driver.get("https://www.baidu.com"

基于Jquery插件Uploadify实现实时显示进度条上传图片

网址:http://www.jb51.net/article/83811.htm 这篇文章主要介绍了基于Jquery插件Uploadify实现实时显示进度条上传图片的相关资料,感兴趣的小伙伴们可以参考一下 先了解了解Uploadify,具体内容如下 Uploadify是一个简单易用的多文件上传方案.作为一个Jquery插件,Uploadify使用简单,并具有高度的定制性. Uploadify特性: Uploadify简单说来,是基于Jquery的一款文件上传插件.它的功能特色总结如下: 1).支

extjs4 分页工具栏pagingtoolbar的每页显示数据combobox下拉框

var itemsPerPage = 20; var combo; //创建数据源store Ext.define('recordStore', { extend : 'Ext.data.Store', // autoLoad : { // start : 0, // limit : itemsPerPage // }, start : 0, limit : itemsPerPage, pageSize : itemsPerPage, model : 'recordModel', proxy :

制作上下分页显示规定条数的效果

我们经常在网页上面浏览页面的时候,都会看到上一页,下一页等这样的跳转那么在PHP中是怎么实现的呢 我们如果要在指定的区域显示规定的数据条数,那么我们怎么实现让多余的数据自己到下一页呢,这里我们就要用到分页了 limit limit 这里是从第几条数据开始,这里是从每页显示几条数据:例如 limit 1,3:从第一条数据开始显示,每页显示三条数据. 例如: $sql = "select * from movie limit $sum,$pageSize"; 当中的$sum和$pageSi

vue分页组件table-pagebar

之前一直接触都是原始的前端模型,jquery+bootstrap,冗杂的dom操作,繁琐的更新绑定.接触vue后,对前端MVVM框架有了全新的认识.本文是基于webpack+vue构建,由于之前的工作主要是基于java的服务端开发工作,对前端框架和组件的理解,不够深入,借此来记录在前端框架使用和构建中的点点滴滴. 此分页组件参照于bootstrap-datatable底部分页开发完成,相关参数增加自定义功能. 最终使用展现效果图如下,数据来源于cnodejs[https://cnodejs.or

【jQuery 分页】jQuery分页功能的实现

自写的jQuery实现分页功能的分页组件: 功能效果如下: 分页组件就是上图中的三部分, 分别放在表格上部  和下部 . 其中, 1>>>页面的代码如下: product.jsp 其中引用bootstrap.css  和bootstrap .js是必须的 1 <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> 2 <%@ ta

可&#8203;根据需求定制的jquery分页

可根据需求定制的jquery分页 本文讲述作者自己用jquery实现的,便于以后使用的分页框架.该分页框架兼容IE,FF,Chrome等主流浏览器,便于移植,可根据需求定制,不需要引入css样式,样式是使用json传入. 1,使用方法: 在需要设置分页的html文件里引入两个文件.一个是jquery.js,另外一个就是jquery.pager.update-1.0.js(这个是核心代码). <script src="jquery.js" type="text/javas