zoukankan      html  css  js  c++  java
  • JavaScript和jQuery动态的数据html页面里的分页效果

    我们从数据拿到消息想动态加载到html页面,这要设计到ajax,这里ajax就不在重新叙述了,现在只讲拿到数据后插入到页面中,并且动态的生成底部的翻页栏效果,用到jQuery库。

    主要思路是这个样子的:

    ①拿到数据总的条数,根据每页放多少个,来生成按钮,切割数据。

    首先老规矩,来个html代码:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <script src="jquery-1.11.3.min.js"></script>

        <script src="index.js"></script>
        <style type="text/css" media="screen">
        .content{
            height:250px !important;
        }
        li{
            margin: 4px 4px;
        }
        .cur{
            background-color: #7218EC;
        }
        </style>
    </head>
    <body>
        <div>
            <input type="button" name="" id="begin" value="begin" onclick="myGetDate(1000)">
            <input type="button" name="" id="end" value="end">
        </div>

      //动态数据插入的地方
        <ul id="content">
        </ul>

      //翻页栏插入的地方
        <ul id="pagesA">
        </ul>
        <ul id="nav">
            <button type="" id="pageP">prev</button>
            <button type="" id="pageN">next</button>
        </ul>
    </body>
    </html>

    这里是js代码的地方inde.js:

    function myGetDate(i){
                var date = new Date();
                var num=0;
                var choiceBar = document.getElementById("pagesA");
                var article = document.getElementById("content");
                //动态的往ul里面插入数据,这个可以从数据库里取出的数据,我本来想弄个时间戳的,功夫不到家,将就的看吧.
                while(i){
                    $("#content").append("<li> Year : " + date.getFullYear() + " Month :" + date.getMonth() + " Day : " + date.getDate() + " hour : " + date.getHours() + " minute : " + date.getMinutes() + " second : " + i) + "</li>";
                    i--;
                }
                //动态的生成分页按钮的个数
                var len = $("#content li").length;
                for(var i=0; i<len/10; i++){
                    $("#pagesA").append("<li style='24px;height:24px;display:inline-block;border: 1px solid #D611EA;text-align:center;line-height:24px;'>" + (i+1) + "</li>");
                }
                $("#pagesA li:first-child").addClass("cur");
                //给每个按钮添加事件
                for(var i=0; i<choiceBar.children.length; i++){
                    choiceBar.children[i].index = i;
                    choiceBar.children[i].onclick = function(){
                        for(var j=0; j<choiceBar.children.length; j++){
                            choiceBar.children[j].className = "";
                        }
                        this.className = "cur";
                        num = this.index;
                        init(num);
                    }
                }
                //上一个按钮添加事件
                $("#pageP").click(function(){
                    if(num==0){                                     //到第一页的情况
                        return false;
                    }else{
                        for(var j=0; j<choiceBar.children.length; j++){
                            choiceBar.children[j].className = "";
                        }
                        choiceBar.children[num-1].className = "cur";
                        init(num-1);
                        return num--;
                    }
                });
                //下个按钮添加事件
                $("#pageN").click(function(){
                    if(num==choiceBar.children.length-1){             //到最后一页的情况
                        return false;
                    }else{
                        for(var j=0; j<choiceBar.children.length; j++){
                            choiceBar.children[j].className = "";
                        }
                        choiceBar.children[num+1].className = "cur";
                        init(num+1);
                        return num++;
                    }
                });
                //显示与按钮对应的十个信息
                function init(myNum){
                    for(var j=0; j<choiceBar.children.length; j++){
                        for(var i=0; i<10; i++){
                            if(article.children[(j*10)+i] == undefined){
                                continue;
                            }
                            article.children[(j*10)+i].style.display = "none";
                        }    
                    }
                    for(var i=0; i<10; i++){
                        if(article.children[(myBum*10)+i] == undefined){
                            continue;
                        }
                        article.children[(myBum*10)+i].style.display = "block";
                    }
                }
                init(0);
            }

  • 相关阅读:
    MySQL单机多实例安装并配置主从复制
    linux编译安装MySQL
    Mysql的float类型造成的困扰总结
    kettle初探
    最近的工作总结
    【spring boot】SpringBoot初学(7)– 多数据源及其事务
    【spring boot】SpringBoot初学(6)– aop与自定义注解
    【spring boot】SpringBoot初学(5)– WebService之Jersey
    SpringBoot初学(4)– JdbcTemplate和Mybatis
    【spring boot】SpringBoot初学(3)– application配置和profile隔离配置
  • 原文地址:https://www.cnblogs.com/JustinBaby/p/5046384.html
Copyright © 2011-2022 走看看