zoukankan      html  css  js  c++  java
  • 分页插件使用的dome

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="format-detection" content="telephone=no,email=no,adress=no">
        <meta name="viewport"
              content="width=device-width,  initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0,  user-scalable=no">
        <meta name="apple-mobile-web-app-capable" content="yes">
        <meta name="apple-mobile-web-app-status-bar-style" content="black">
        <title>simplePaging-简洁易用的分页插件</title>
        <style>
            * {
                margin: 0;
                padding: 0;
            }
    
            body {
                font: 14px/1.42857143 'Microsoft YaHei', '微软雅黑', '宋体';
                color: #333;
                background-color: #fff;
                min- 1220px;
                max- 1920px;
                margin: 0 auto;
            }
    
            .instructions {
                float: right;
                margin: 20px;
                 700px;
            }
    
            .instructions table {
                 100%;
            }
    
            .instructions table th,
            .instructions table td {
                 15%;
                text-align: center;
                border: 1px solid #ccc;
            }
    
            .instructions table th:last-child,
            .instructions table td:last-child {
                 55%;
                padding-left: 5px;
                text-align: left;
            }
    
            .part {
                margin: 20px;
            }
    
            .part p {
                padding-left: 2px;
            }
            .red{
                color: red;
            }
            .page{
                height: 30px;
                line-height: 30px;
            }
        </style>
        <link rel="stylesheet" href="css/simplePaging.css">
        <script src="http://www.jq22.com/jquery/jquery-1.10.2.js"></script>
        <script src="js/simplePaging.js"></script>
    </head>
    <body>
    <!--文档说明 开始-->
    <!--
    <div class="instructions">
        <strong>文档说明:</strong>
        <table cellpadding="0" cellspacing="0" border="0">
            <tr>
                <th>参数名</th>
                <th>参数类型</th>
                <th>可选参数</th>
                <th>说明</th>
            </tr>
            <tr>
                <td>allPage</td>
                <td>number</td>
                <td>自定义数字</td>
                <td>默认值:12。<span class="red">总页数</span>:页码器总共多少页。</td>
            </tr>
            <tr>
                <td>showPage</td>
                <td>number</td>
                <td>自定义数字</td>
                <td>默认值:5。<span class="red">显示页数</span>:页码器显示几页。</td>
            </tr>
            <tr>
                <td>startPage</td>
                <td>number</td>
                <td>自定义数字</td>
                <td>默认值:1。<span class="red">首页页码数字。</span></td>
            </tr>
            <tr>
                <td>initPage</td>
                <td>number</td>
                <td>自定义数字</td>
                <td>默认值:1。<span class="red">加载完毕自动跳转到第n页</span>:此值小于<span class="red">startPage</span>则跳转首页,反之跳转尾页。</td>
            </tr>
            <tr>
                <td>initPageClick</td>
                <td>boolean</td>
                <td>true或false</td>
                <td>默认值:true(回调)。<span class="red">每次页面加载完毕后,是否触发initPage页的绑定事件</span>,false不回调。</td>
            </tr>
            <tr>
                <td>first</td>
                <td>string</td>
                <td>自定义字符串</td>
                <td>默认值:"首页"。<span class="red">首页显示字符</span>。</td>
            </tr>
            <tr>
                <td>last</td>
                <td>string</td>
                <td>自定义字符串</td>
                <td>默认值:"尾页"。<span class="red">尾页显示字符</span>。</td>
            </tr>
            <tr>
                <td>prev</td>
                <td>string</td>
                <td>自定义字符串</td>
                <td>默认值:"«"。<span class="red">上一页显示字符</span>。</td>
            </tr>
            <tr>
                <td>next</td>
                <td>string</td>
                <td>自定义字符串</td>
                <td>默认值:"»"。<span class="red">下一页显示字符</span>。</td>
            </tr>
            <tr>
                <td>showTurnTo</td>
                <td>boolean</td>
                <td>true或false</td>
                <td>默认值:false(不显示)。<span class="red">是否显示“跳转”项</span>,true时显示。为true时,页码输入框输入完毕,按下<span class="red">回车键即可立即执行跳转</span>。输入页码小于<span class="red">startPage</span>跳转首页,反之跳至尾页。</td>
            </tr>
            <tr>
                <td>animateType</td>
                <td>string</td>
                <td>
                    "animation"<br/>
                    "jumpy"<br/>
                    "fast"<br/>
                    "normal"<br/>
                    "slow"<br/>
                    "verySlow"
                </td>
                <td>
                    默认值:"animation"。<span class="red">动画过渡模式</span>。<br/>
                    立即,对应animationTime=0<br/>
                    100ms,对应animationTime=100<br/>
                    200ms,对应animationTime=200<br/>
                    400ms,对应animationTime=400<br/>
                    800ms,对应animationTime=800<br/>
                </td>
            </tr>
            <tr>
                <td>animationTime</td>
                <td>number</td>
                <td>自定义数字</td>
                <td>默认值:300。<span class="red">仅为animateType为animation时生效</span>,设置<span class="red">动画过渡时间(ms)</span>。</td>
            </tr>
            <tr>
                <td>callBack</td>
                <td>function</td>
                <td>自定义方法</td>
                <td>默认值:打印页码。用于<span class="red">回调函数扩展方法</span>。</td>
            </tr>
        </table>
    </div>
    <!–文档说明 结束–>
    
    
    <!–demo 开始–>
    
    <!–默认–>
    <div class="part part1">
        <p>默认:</p>
        <div class="simplePaging"></div>
        <script>
            $(".simplePaging").simplePaging();
        </script>
    </div>
    
    
    <!–总页数88,显示页数8–>
    <div class="part part2">
        <p>总页数88,显示页数8:</p>
        <div class="simplePaging2"></div>
        <script>
            $(".simplePaging2").simplePaging({
                allPage: 88,//总页数
                showPage: 8//显示页数
            });
        </script>
    </div>
    
    
    <!–第一页数字6,初始化跳转到8–>
    <div class="part part3">
        <p>第一页数字6,初始化跳转到8:</p>
        <div class="simplePaging3"></div>
        <script>
            $(".simplePaging3").simplePaging({
                allPage: 88,//总页数
                showPage: 9,//显示页数
                startPage: 6,//第一页页码数字
                initPage: 8//加载完毕自动跳转到第n页
            });
        </script>
    </div>
    
    
    <!–animationTime设置为50,回调显示页码–>
    <div class="part part4">
        <p>animationTime设置为50,回调显示页码:</p>
        <div class="simplePaging4"></div>
        <div class="page simplePaging4PageNum"></div>
        <script>
            $(".simplePaging4").simplePaging({
                allPage: 88,//总页数
                showPage: 9,//显示页数
                startPage: 1,//第一页页码数字
                initPage: 5,//加载完毕自动跳转到第n页
                animateType: "animation",//过渡模式:动画“animation”、跳动“jumpy”、快速移动“fast”、正常速度移动“normal”、缓慢的速度移动“slow”、异常缓慢的速度移动“verySlow”
                animationTime: 50,//animateType为animation时,动画过渡时间(ms)
                callBack: function (num) {
                    $(".simplePaging4PageNum").text(num)
                }
            });
        </script>
    </div>
    
    
    <!–animateType为"jumpy"–>
    <div class="part part5">
        <p>animateType为"jumpy":</p>
        <div class="simplePaging5"></div>
        <div class="page simplePaging5PageNum"></div>
        <script>
            $(".simplePaging5").simplePaging({
                allPage: 88,//总页数
                showPage: 9,//显示页数
                animateType: "jumpy",//过渡模式:动画“animation”、跳动“jumpy”、快速移动“fast”、正常速度移动“normal”、缓慢的速度移动“slow”、异常缓慢的速度移动“verySlow”
                callBack: function (num) {
                    $(".simplePaging5PageNum").text(num)
                }
            });
        </script>
    </div>
    
    
    <!–animateType为"verySlow"–>
    <div class="part part6">
        <p>animateType为"verySlow":</p>
        <div class="simplePaging6"></div>
        <div class="page simplePaging6PageNum"></div>
        <script>
            $(".simplePaging6").simplePaging({
                allPage: 88,//总页数
                showPage: 9,//显示页数
                startPage: 6,//第一页页码数字
                initPage: 18,//加载完毕自动跳转到第n页
                first: "首页",//首页显示字符
                last: "尾页",//尾页显示字符
                prev: "«",//上一页显示字符
                next: "»",//下一页显示字符
                animateType: "verySlow",//过渡模式:动画“animation”、跳动“jumpy”、快速移动“fast”、正常速度移动“normal”、缓慢的速度移动“slow”、异常缓慢的速度移动“verySlow”
                callBack: function (num) {
                    $(".simplePaging6PageNum").append(num+"    ")
                }
            });
        </script>
    </div>
    -->
    
    <!--显示跳转按钮-->
    <div class="part part7">
        <p>显示跳转按钮:</p>
        <div class="simplePaging7"></div>
        <div class="page simplePaging7PageNum"></div>
        <script>
            $(".simplePaging7").simplePaging({
                allPage: 10,//总页数
                showPage: 5,//显示页数
                startPage: 1,//第一页页码数字
                initPage: 1,//加载完毕自动跳转到第n页
                showTurnTo: true,//是否显示跳转按钮,false不显示,true显示
                animateType: "normal",//过渡模式:动画“animation”、跳动“jumpy”、快速移动“fast”、正常速度移动“normal”、缓慢的速度移动“slow”、异常缓慢的速度移动“verySlow”
                animationTime: 300,//animateType为animation时,动画过渡时间(ms)
                callBack: function (num) {
                    $.ajax({
                        type:'GET',
                        //发送请求的地址以及传输的数据
                        url:'https://www.apiopen.top/satinCommentApi?id=27610708&page='+num+'',
                        //服务器返回的数据类型
                        dataType:'json',
                        success:function(data){
                           var a=data.data.normal.list;
                            console.log(a)
                            $(".simplePaging7PageNum").empty();
                           for(var i=0;i< a.length;i++){
                               $(".simplePaging7PageNum").append(a[i].content+'<br/>')
                           }
                        },
                        error:function(jqXHR){
                            alert(0)
                        }
                    });
    
    
                }
            });
        </script>
    </div>
    
    <!--显示跳转按钮(页面加载完毕不回调callBack)-->
    <!--<div class="part part8">
        <p>显示跳转按钮(每次页面第一次加载完毕不回调callBack):</p>
        <div class="simplePaging8"></div>
        <div class="page simplePaging8PageNum"></div>
        <script>
            $(".simplePaging8").simplePaging({
                allPage: 88,//总页数
                showPage: 9,//显示页数
                startPage: 1,//第一页页码数字
                initPage: 1,//加载完毕自动跳转到第n页
                initPageClick:false,//每次页面加载完毕后,是否触发initPage页的绑定事件
                showTurnTo: true,//是否显示跳转按钮,false不显示,true显示
                animateType: "normal",//过渡模式:动画“animation”、跳动“jumpy”、快速移动“fast”、正常速度移动“normal”、缓慢的速度移动“slow”、异常缓慢的速度移动“verySlow”
                animationTime: 300,//animateType为animation时,动画过渡时间(ms)
                callBack: function (num) {
                    $(".simplePaging8PageNum").append(num+"    ")
                }
            });
        </script>
    </div>-->
    
    
    
    <!--demo 结束-->
    </body>
    </html>
    

      css

    .spPage ul li,
    .spActiveBg,
    .spPrev,
    .spFirst,
    .spLast,
    .spNext,
    .spTurnTo input,
    .spTurnTo .btn {
        display: inline-block;
         28px;
        height: 28px;
        line-height: 28px;
        border: 1px solid #ddd;
        font-size: 12px;
        text-align: center;
        vertical-align: top;
    
        *display: block;
        *float: left;
    }
    
    .spPage ul li,
    .spActiveBg,
    .spPrev,
    .spFirst,
    .spLast,
    .spNext,
    .spTurnTo .btn {
        -moz-user-select: none;
        -khtml-user-select: none;
        user-select: none;
        cursor: pointer;
    }
    
    .spPage ul li:active,
    .spActiveBg:active,
    .spPrev:active,
    .spFirst:active,
    .spLast:active,
    .spNext:active,
    .spTurnTo .btn:active {
        color: #f90;
    }
    
    .spPrev,
    .spNext {
        font-size: 16px;
    
    }
    
    .spPage {
        display: inline-block;
        font-size: 0;
        height: 30px;
        vertical-align: top;
        *display: block;
        *float: left;
    }
    
    .spTurnTo {
        position: relative;
        display: inline-block;
        font-size: 0;
         65px;
        height: 30px;
        vertical-align: top;
        margin-left: 10px;
        *display: block;
        *float: left;
    }
    
    .spTurnTo input {
        *margin-left: -10px;
    }
    
    .spTurnTo input:focus {
        outline: 0;
    }
    
    .spTurnTo .btn {;
        margin-left: 5px;
    }
    
    .spTurnToAllPageTip {
        display: none;
        position: absolute;
         100%;
        height: 100%;
        line-height: 30px;
        top: -100%;
        font-size: 12px;
        text-align: center;
        left: 0;
        background-color: #ccc;
        z-index: 3;
        color: #000;
    }
    
    .spTurnTo input:focus ~ .spTurnToAllPageTip {
        display: block;
    }
    
    .spTurnTo:hover .spTurnToAllPageTip {
        *display: block;
    }
    
    .spPage .spCover {
        position: relative;
         150px;
        height: 30px;
        overflow: hidden;
    }
    
    .spActiveBg {
        position: absolute;
        top: 0;
        left: 0;
        border: 1px solid transparent;
        background-color: #367fa9;
        z-index: 2;
    }
    
    .spPage ul {
        position: absolute;
        top: 0;
        left: 0;
         390px;
        font-size: 0;
        overflow: hidden;
    }
    
    .spPage ul li {
        list-style-type: none;
        overflow: hidden;
    }
    
    .spPage ul li p {
        position: relative;
        z-index: 3;
    }
    
    .spPage ul li.active {
        color: #fff;
    }
    

      js

    /*
     *  原创-反馈请邮件至:361899429@qq.com
     *  创建于20180426     最后修改20180510
     */
    (function ($) {
        $.fn.extend({
            simplePaging: function (opts) {
                //设置默认参数
                var opt = {
                    allPage: 12,//总页数
                    showPage: 5,//显示页数
                    startPage: 1,//第一页页码数字
                    initPage: 1,//加载完毕自动跳转到第n页(初始化激活页)
                    initPageClick:true,//每次页面加载完毕后,是否触发initPage页的绑定事件
                    first: "首页",//首页显示字符
                    last: "尾页",//尾页显示字符
                    prev: "«",//上一页显示字符
                    next: "»",//下一页显示字符
                    showTurnTo: false,//是否显示跳转按钮,true显示,false不显示
                    animateType: "animation",//过渡模式:动画“animation”、跳动“jumpy”、快速移动“fast”、正常速度移动“normal”、缓慢的速度移动“slow”、异常缓慢的速度移动“verySlow”
                    animationTime: 300,//animateType为animation时,动画过渡时间(ms)
                    callBack: function (num) {
                        console.log(num)
                    }
                };
                //合并参数
                var option = $.extend(opt, opts);
                /*初始化激页码不能大于或小于开始页码*/
                if (option.initPage < option.startPage) {
                    option.initPage = option.startPage
                } else if (option.initPage > option.startPage + option.allPage - 1) {
                    option.initPage = option.startPage + option.allPage - 1
                }
                /*过渡模式跳动时间设置*/
                if (option.animateType !== "animation") {
                    switch (option.animateType) {
                        case "jumpy":
                            option.animationTime = 0;
                            break;
                        case "fast":
                            option.animationTime = 100;
                            break;
                        case "normal":
                            option.animationTime = 200;
                            break;
                        case "slow":
                            option.animationTime = 400;
                            break;
                        case "verySlow":
                            option.animationTime = 800;
                            break;
                    }
                }
                /*显示页至少有1页,并且不能大于总页数*/
                option.showPage <= 0 ? option.showPage = 1 : option.showPage;
                option.showPage > option.allPage ? option.showPage = option.allPage : option.showPage;
                /***************/
                var dialog = {};
                var simplePaging = $(this);
                var spPrev = $("<div class='spPrev'>");
                var spFirst = $("<div class='spFirst'>");
                var spPage = $("<div class='spPage'>");
                var spCover = $("<div class='spCover'>");
                var spActiveBg = $("<div class='spActiveBg'>");
                var spLast = $("<div class='spLast'>");
                var spNext = $("<div class='spNext'>");
                var spTurnTo = $("<div class='spTurnTo'>");
                var ul = $("<ul>");
                var delay = false;//延时,不用修改,此项用于前一个点击未完全执行时,阻止其它事件触发
                var init = true;//是否初始化加载页面
                var centerShowPage;
                if (option.showPage % 2 === 0) {
                    centerShowPage = Math.floor((option.showPage - 1) / 2)
                } else {
                    centerShowPage = Math.floor(option.showPage / 2)
                }
                /*程序开始*/
                dialog.init = function () {
                    //插件页码
                    ul.append(spActiveBg);
                    for (var i = 0, j = option.startPage; i < option.allPage; i++, j++) {
                        var li = $("<li>");
                        li.html("<p>" + j + "</p>").on("click", function () {
                            if (!delay) {
                                changePage($(this).text())
                            }
                        });
                        ul.append(li)
                    }
                    //上一页
                    spPrev.text(option.prev).on("click", function () {
                        if (!delay) {
                            var num = ul.find("li.active").text() - 1;
                            changePage(num)
                        }
                    });
                    //首页
                    spFirst.text(option.first).on("click", function () {
                        if (!delay) {
                            var num = ul.find("li:first").text();
                            changePage(num)
                        }
                    });
                    //尾页
                    spLast.text(option.last).on("click", function () {
                        if (!delay) {
                            var num = ul.find("li:last").text();
                            changePage(num)
                        }
                    });
                    //下一页
                    spNext.text(option.next).on("click", function () {
                        if (!delay) {
                            var num = ul.find("li.active").text() - 0 + 1;
                            changePage(num)
                        }
                    });
                    spCover.append(ul);
                    spPage.append(spCover);
                    simplePaging.append(spPrev, spFirst, spPage, spLast, spNext);
                    spCover.width(ul.find("li").outerWidth(true) * option.showPage);//页码中间宽度
                    ul.width(ul.find("li").outerWidth(true) * option.allPage).find("li").eq(option.initPage - option.startPage).trigger("click");//页码总宽度
                    //显示跳转
                    if (option.showTurnTo) {
                        var input = $("<input type='text'>");
                        var btn = $("<div class='btn'>");
                        var spTurnToAllPageTip = $("<div class='spTurnToAllPageTip'>");
                        input.val(option.startPage).change(function () {
                            var num = $(this).val();
                            num > (option.allPage + option.startPage - 1) ? num = (option.allPage + option.startPage - 1) : num;
                            num <= option.startPage ? num = option.startPage : num;
                            $(this).val(num);
                        });
                        btn.text("跳转").on("click", function () {
                            if (!delay) {
                                var num = input.val();
                                changePage(num)
                            }
                        });
                        $(document).keyup(function (event) {
                            var e = event || window.event;
                            var k = e.keyCode || e.which;
                            if (k == 13 && input.is(":focus")) {
                                btn.trigger("click");
                                input.blur();
                            }
                        });
                        spTurnToAllPageTip.text("共" + (option.allPage + option.startPage - 1) + "页");
                        spTurnTo.append(input, btn, spTurnToAllPageTip);
                        simplePaging.append(spTurnTo).width(ul.find("li").outerWidth(true) * (option.showPage + 6) + 15);
                    } else {
                        simplePaging.width(ul.find("li").outerWidth(true) * (option.showPage + 4));
                    }
                };
                /*改变页码函数*/
                function changePage(num) {
                    if (num < option.startPage || num > option.allPage + option.startPage - 1) {
                        return false;
                    } else if (ul.find("li.active").text() == num&&!init) {
                        return false;
                    } else if (isNaN(num)) {
                        return false;
                    }
                    delay = !delay;
                    num = Number(num);
                    var leng = num - option.startPage;
                    var liWidth = ul.find("li").outerWidth(true);
                    ul.find("li.active").removeClass("active");
                    spActiveBg.animate({"left": liWidth * (num - option.startPage)}, option.animationTime);
                    if (leng <= centerShowPage) {
                        ul.animate({"left": 0}, option.animationTime, function () {
                            autoActive()
                        });
                    } else if (leng >= option.allPage - centerShowPage - 1) {
                        ul.animate({"left": -liWidth * (option.allPage - option.showPage)}, option.animationTime, function () {
                            autoActive()
                        });
                    } else {
                        ul.animate({"left": -liWidth * (leng - centerShowPage)}, option.animationTime, function () {
                            autoActive()
                        });
                    }
                    function autoActive() {
                        delay = !delay;
                        ul.find("li").eq(num - option.startPage).addClass("active");
                        if(init){
                            init = false;
                            if(option.initPageClick){
                                option.callBack(num);
                            }
                        }else {
                            option.callBack(num);
                        }
                    }
                }
    
                dialog.init();
            }
        });
    })(jQuery);
    

      

  • 相关阅读:
    开篇词The Start以及[Vjudge][HDU2242]空调教室
    [故地重游][NOIP2019]格雷码
    关于非触
    致诸君
    三角形的概率
    [HDU5970] 最大公约数
    [51Nod1534] 棋子游戏
    [TJOI2018] 数学计算
    [CF938D] Buy a Ticket
    [HDU4143] A Simple Problem
  • 原文地址:https://www.cnblogs.com/9608kai/p/9055602.html
Copyright © 2011-2022 走看看