帶省略的分頁

這個ajax分頁是基本jquery來實現的,足以知足正常需求。。。html

效果:
圖片描述jquery

HTML:ajax

<div class="zh-page zh-align-center">
    <ul>
        <!-- <li class="zh-prev"><a href="###"><span class="zh-icon-prev"></span></a></li>
        <li class="zh-cur"><a href="###">1</a></li>
        <li><a href="###">2</a></li>
        <li><a href="###">3</a></li>
        <li><a href="###">4</a></li>
        <li><a href="###">5</a></li>
        <li class="zh-ellipsis">...</li>
        <li class="zh-cur"><a href="###">20</a></li>
        <li class="zh-next"><a href="###"><span class="zh-icon-next"></span></a></li>
        <li class="zh-total">共21頁</li> -->
    </ul>
</div>

CSS:this

.zh-page{height: 20px;padding: 20px 0;text-align: right;}
.zh-page ul{display: inline-block;height: 20px;}
.zh-page ul li{float: left;height: 20px;line-height: 20px;margin: 0 3px;color: #fff;font-size: 14px;}
.zh-page ul li a{display: block;height: 100%;min-width: 10px;border-radius: 10px;padding: 0 5px;color: #fff;}
.zh-page ul .zh-cur a{background-color: #4DDDF2;color: #1c1c1c;}
.zh-page .zh-icon-prev,
.zh-page .zh-icon-next{display: inline-block;width: 0;height: 0;border-style: solid;border-width: 4px 6px;border-color: transparent #858587 transparent transparent;}
.zh-page .zh-icon-next{border-color: transparent transparent transparent #858587;}

JS:spa

$.extend({
    // ajax分頁
    page: function(options) {
        var defaults = {
            'visiblePages': 6 // 可見頁碼(不能小於4)
        };
        var opts = $.extend({}, defaults, options);
        var curPage = opts.curPage;
        // 建立分頁列表
        function createPageList(curPage) {
            var li = '<li class="zh-prev"><a href="###"><span class="zh-icon-prev"></span></a></li>';
            if(opts.totalPages <= opts.visiblePages) { // 總頁數<=可見頁
                for(var i=1; i<=opts.totalPages; i++) {
                    if(curPage == i) {
                        li += '<li class="zh-cur"><a href="###">'+i+'</a></li>';
                    } else {
                        li += '<li><a href="###">'+i+'</a></li>';
                    }
                }
            } else { // 總頁數>可見頁
                if(curPage < opts.visiblePages-1) { // 當前頁<可見頁-1
                    for(var i=1; i<=opts.visiblePages-1; i++) {
                        if(curPage == i) {
                            li += '<li class="zh-cur"><a href="###">'+i+'</a></li>';
                        } else {
                            li += '<li><a href="###">'+i+'</a></li>';
                        }
                    }
                    li += '<li class="zh-ellipsis">...</li>';
                    li += '<li><a href="###">'+opts.totalPages+'</a></li>';
                } else if(curPage >= opts.visiblePages-1) {  // 當前頁>=可見頁-1
                    if(opts.totalPages-curPage <= opts.visiblePages-4) { // 能連到結束
                        li += '<li><a href="###">1</a></li>';
                        li += '<li class="zh-ellipsis">...</li>';
                        for(var i=opts.totalPages-(opts.visiblePages-2); i<=opts.totalPages; i++) {
                            if(curPage == i) {
                                li += '<li class="zh-cur"><a href="###">'+i+'</a></li>';
                            } else {
                                li += '<li><a href="###">'+i+'</a></li>';
                            }
                        }
                    } else { // 不能連到結束
                        li += '<li><a href="###">1</a></li>';
                        li += '<li class="zh-ellipsis">...</li>';
                        for(var i=curPage-(opts.visiblePages-4); i<=curPage+1; i++) {
                            if(curPage == i) {
                                li += '<li class="zh-cur"><a href="###">'+i+'</a></li>';
                            } else {
                                li += '<li><a href="###">'+i+'</a></li>';
                            }
                        }
                        li += '<li class="zh-ellipsis">...</li>';
                        li += '<li><a href="###">'+opts.totalPages+'</a></li>';
                    }
                }
            }
            li += '<li class="zh-next"><a href="###"><span class="zh-icon-next"></span></a></li>';
            li += '<li class="zh-total">共'+opts.totalPages+'頁</li>';
            $(opts.ele).html(li);
        }
        createPageList(curPage);
        // 點擊頁碼
        $(opts.ele).off('click');
        $(opts.ele).on('click', 'li:not(.zh-prev, .zh-next, .zh-total, .zh-ellipsis)', function() {
            curPage = +$(this).text();
            $(this).addClass('zh-cur').siblings().removeClass('zh-cur');
            createPageList(curPage);
            if(opts.change && typeof opts.change === 'function') {
                opts.change.call(null, curPage);
            }
        });
        // 點擊前一頁
        $(opts.ele).on('click', '.zh-prev', function() {
            curPage = +$(opts.ele).children('.zh-cur').text();
            curPage--;
            if(curPage < 1) return;
            createPageList(curPage);
            if(opts.change && typeof opts.change === 'function') {
                opts.change.call(null, curPage);
            }
        });
        // 點擊後一頁
        $(opts.ele).on('click', '.zh-next', function() {
            curPage = +$(opts.ele).children('.zh-cur').text();
            curPage++;
            if(curPage > opts.totalPages) return;
            createPageList(curPage);
            if(opts.change && typeof opts.change === 'function') {
                opts.change.call(null, curPage);
            }
        });
    }
});

調用:code

$.page({
    ele: '.zh-page ul',
    curPage: 1, // 當前頁
    visiblePages: 5, // 可見頁碼
    change: function(num) { // 回調
        // alert(num);
    },
    totalPages: 20 // 總頁數
});
相關文章
相關標籤/搜索