首页 > 其他分享 >分页制作

分页制作

时间:2023-03-24 19:36:28浏览次数:26  
标签:index right 分页 res list height 制作 left

HTML代码

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<style>
    *{
        margin: 0 ; 
        padding: 0;
        list-style-type: none;
    }
    .pagWarp{
        height: 40px;
        box-shadow: 0 2px 5px #b6b6b6;
        position: absolute;
        border-radius: 2px;
        right: 42%;
        top: 430px;
    }
    #btnL,#btnR{
        line-height: 40px;
        cursor: pointer;
    }
    #btnL{
        float: left;
    }
    #btnR{
        float: right;             
    }
    .pagWarp ul{        
        height: 40px;
        margin: 0 auto;
        float: left;
        text-align: center;
        padding-left: 40px;
        padding-right: 40px;
    }
    .pagWarp ul li{
        float: left;
        text-align: center;
        line-height: 40px;
        padding: 0 4px;
    }
    .active{
        color: blue;
        font-size: 30px;
    }

    /* 商品列表样式 */
.list{
    width: 80%;
    margin: 20px auto;
}
.list:after{
    content:'';
    display: block;
    clear: both;
}
.list li{
    padding:2%;
    width: 15%;
    float: left;
    height: 300px;
    color: #666;
    border-right: 1px solid #b6b6b6;
      box-shadow: 2px 2px 5px #b6b6b6;  
      margin-left: 8px;
      margin-top: 20px;
}
.list li h2{
    font-size: 18px;
    text-align: center;
    line-height: 30px;
}
.list .img{
    width: 100%;
    border: 1px solid #b6b6b6;
    height: 180px;
}
.list input[type=button]{
    display: block;
    margin: 0 auto;
    border: 1px solid #b6b6b6;
    width: 100px;
    height: 80px;
}
</style>
<body>
    <ul class="list" id="list">
       
    </ul>
    <div class="pagWarp" id="pageWarp">
        <li id="btnL">上一页</li>
        <ul>
        </ul>
        <li id="btnR">下一页</li>
    </div>
</body>
<script src="ajax.js"></script>
<script src="index.js"></script>
</html>

index.js

; (function(){
    "use strict";
    class Page{
        constructor(){
                this.url="http://localhost/1908/page/goods.json",
                this.cont=document.getElementById('list'),
                this.pageCont=document.querySelector('#pageWarp ul'),
                this.left=document.getElementById("btnL"),
                this.right=document.getElementById("btnR"),
                this.num=5,
                this.index=0
             // 1.开启ajax,请求数据
             this.load();
             // 4.绑定点击事件
             this.addEvent();
        }
        addEvent(){
            var that = this;
            // 5.事件被触发时,改变索引(页码)
            this.left.onclick = function(){
                that.changeIndex(-1)
            }
            this.right.onclick = function(){
                that.changeIndex(1)
            }
        }
        changeIndex(type){
            // 计算页码
            if(type == -1){
                if(this.index == 0){
                    this.index = this.maxNum-1;
                }else{
                    this.index--;
                }
            }else{
                if(this.index == this.maxNum-1){
                    this.index = 0;
                }else{
                    this.index++;
                }
            }
            // 渲染样式
            this.active();
            // 6.修改页面数据
            this.display();
        }
        load(){
            ajax({
                url:this.url,
                success:res=>{
                    // 2.请求数据成功,解析数据,准备渲染页面
                    this.res = JSON.parse(res);
                    // 3.创建页码
                    this.createPage();
                    this.display();
                }
            })
        }
        createPage(){
            // 计算最大页码数
            this.maxNum = Math.ceil(this.res.length / this.num)
            // 生成页码的结构
            var str = "";
            for(var i=0;i<this.maxNum;i++){
                str += `<li>${i+1}</li>`;
            }
            this.pageCont.innerHTML = str;
            this.active();//让默认的index有样式。
        }
        active(){
            // 设置当前项的功能
            for(var i=0;i<this.maxNum;i++){
                this.pageCont.children[i].className = "";
            }
            this.pageCont.children[this.index].className = "active";
        }
        display(){
            var str = "";
            // 分页的核心部分:
            // 一页数据有限,不能够从0到length-1了
            // 0~5     this.num5*this.index0   ~   this.num5*(this.index0+1)
            // 5~10    this.num5*this.index1   ~   this.num5*(this.index1+1)
            // 10~15   this.num5*this.index2   ~   this.num5*(this.index2+1)

            for(var i=this.num*this.index;i<this.num*(this.index+1);i++){
                if(i<this.res.length){
                    str += `<li>
                            <img src="${this.res[i].url}" alt="" class="img">        
                            <h2>商品名称:<span>${this.res[i].name}</span></h2>
                            <h2>商品介绍:<span>${this.res[i].tip}</span></h2>
                            <h2>商品价格:<span>${this.res[i].price}</span></h2>
                        </li>`;
                }
            }
            this.cont.innerHTML = str;
        }
    }

    new Page;

    // window.page = Page;
})();

另一种方法写:html(可以适应不同情况调用) .这个用了return方法

html:

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<style>
    *{
        margin: 0 ; 
        padding: 0;
        list-style-type: none;
    }
    .pagWarp{
        height: 40px;
        box-shadow: 0 2px 5px #b6b6b6;
        position: absolute;
        border-radius: 2px;
        right: 42%;
        top: 430px;
    }
    #btnL,#btnR{
        line-height: 40px;
        cursor: pointer;
    }
    #btnL{
        float: left;
    }
    #btnR{
        float: right;             
    }
    .pagWarp ul{        
        height: 40px;
        margin: 0 auto;
        float: left;
        text-align: center;
        padding-left: 40px;
        padding-right: 40px;
    }
    .pagWarp ul li{
        float: left;
        text-align: center;
        line-height: 40px;
        padding: 0 4px;
    }
    .active{
        color: blue;
        font-size: 30px;
    }

    /* 商品列表样式 */
.list{
    width: 80%;
    margin: 20px auto;
}
.list:after{
    content:'';
    display: block;
    clear: both;
}
.list li{
    padding:2%;
    width: 15%;
    float: left;
    height: 300px;
    color: #666;
    border-right: 1px solid #b6b6b6;
      box-shadow: 2px 2px 5px #b6b6b6;  
      margin-left: 8px;
      margin-top: 20px;
}
.list li h2{
    font-size: 18px;
    text-align: center;
    line-height: 30px;
}
.list .img{
    width: 100%;
    border: 1px solid #b6b6b6;
    height: 180px;
}
.list input[type=button]{
    display: block;
    margin: 0 auto;
    border: 1px solid #b6b6b6;
    width: 100px;
    height: 80px;
}
</style>
<body>
    <ul class="list" id="list">
       
    </ul>
    <div class="pagWarp" id="pageWarp">
        <li id="btnL">上一页</li>
        <ul>
        </ul>
        <li id="btnR">下一页</li>
    </div>
</body>
<script src="../ajax.js"></script>
<script src="index.js"></script>
<script>
    new page({
        url:"http://localhost/1908/page/goods.json",
        cont:document.getElementById('list'),
        pageCont:document.querySelector('#pageWarp ul'),
        left:document.getElementById("btnL"),
        right:document.getElementById("btnR"),
        num:5,
        index:0
    });
</script>
</html>

index.js

;var page = (function(){
    "use strict";
    class Page{
        constructor(options){
            this.url = options.url;
            this.cont = options.cont;
            this.pageCont = options.pageCont;
            this.left = options.left;
            this.right = options.right;
            this.num = options.num;
            this.index = options.index;
    
            // 1.开启ajax,请求数据
            this.load();
            // 4.绑定点击事件
            this.addEvent();
        }
        addEvent(){
            var that = this;
            // 5.事件被触发时,改变索引(页码)
            this.left.onclick = function(){
                that.changeIndex(-1)
            }
            this.right.onclick = function(){
                that.changeIndex(1)
            }
        }
        changeIndex(type){
            // 计算页码
            if(type == -1){
                if(this.index == 0){
                    this.index = this.maxNum-1;
                }else{
                    this.index--;
                }
            }else{
                if(this.index == this.maxNum-1){
                    this.index = 0;
                }else{
                    this.index++;
                }
            }
            // 渲染样式
            this.active();
            // 6.修改页面数据
            this.display();
        }
        load(){
            ajax({
                url:this.url,
                success:res=>{
                    // 2.请求数据成功,解析数据,准备渲染页面
                    this.res = JSON.parse(res);
                    // 3.创建页码
                    this.createPage();
                    this.display();
                }
            })
        }
        createPage(){
            // 计算最大页码数
            this.maxNum = Math.ceil(this.res.length / this.num)
            // 生成页码的结构
            var str = "";
            for(var i=0;i<this.maxNum;i++){
                str += `<li>${i+1}</li>`;
            }
            this.pageCont.innerHTML = str;
            // 设置默认当前项
            this.active();
        }
        active(){
            // 设置当前项的功能
            for(var i=0;i<this.pageCont.children.length;i++){
                this.pageCont.children[i].className = "";
            }
            this.pageCont.children[this.index].className = "active";
        }
        display(){
            var str = "";
            // 分页的核心部分:
            // 一页数据有限,不能够从0到length-1了
            // 0~5     this.num5*this.index0   ~   this.num5*(this.index0+1)
            // 5~10    this.num5*this.index1   ~   this.num5*(this.index1+1)
            // 10~15   this.num5*this.index2   ~   this.num5*(this.index2+1)

            for(var i=this.num*this.index;i<this.num*(this.index+1);i++){
                if(i<this.res.length){
                    str += `<li>
                            <img src="${this.res[i].url}" alt="" class="img">        
                            <h2>商品名称:<span>${this.res[i].name}</span></h2>
                            <h2>商品介绍:<span>${this.res[i].tip}</span></h2>
                            <h2>商品价格:<span>${this.res[i].price}</span></h2>
                        </li>`;
                }
            }
            this.cont.innerHTML = str;
        }
    }

    return Page;

    // window.page = Page;
})();

ajax封装代码,json代码不再写上了。知道方法就行

长风破浪会有时,直挂云帆济沧海



标签:index,right,分页,res,list,height,制作,left
From: https://blog.51cto.com/u_15961676/6147971

相关文章

  • PHP网站安装程序制作 (附:模块检测的方法)
    ManywebapplicationssuchasWordPressleadyouthroughthewholeinstallationprocessfromaskingforSQLdetailstogettingsomeuserlogindetailsetc. Due......
  • 分页机制及映射过程
    分页机制和映射过程x86:CR3-PDT-PTT-offset10-10-12x86withPAE:CR3-PDPT-PDT-PTT-offset2-9-9-12EPT(x64):EPTP-PML4E-PDPTE-PDE-PTE-o......
  • 教你如何使用QT制作一个ListView列表
    导读这篇文章主要为大家详细介绍了如何使用Qt制作一个ListView,点击ListView的Item可以用于测试OpenCV的各种效果,感兴趣的小伙伴可以了解一下1、概述案例:使用Qt制......
  • 英雄联盟比赛选手的六芒星能力图动画是如何制作的?
    最近,在看LPL比赛的时候,看到这样一个有意思的六芒星能力图动画:今天,我们就来使用纯CSS实现这样一个动画效果!实现背景网格对于如下这样一个背景网格,最好的方式当然肯......
  • 数据量很大的情况下,对于分页查询你有什么优化方案吗?
    当需要从数据库查询的表有上万条记录的时候,一次性查询所有结果会变得很慢,特别是随着数据量的增加特别明显,这时需要使用分页查询。对于数据库分页查询,也有很多种方法和优化......
  • 常见B端产品经理面试问题及答案(二)【11年大厂面试官呕心制作】
    我会一直长期给你分享B端产品经理面试问题大全及答案合集,助你斩获心仪offer!请你去工粽号【B端产品经理面试官Aadi】并设为星标,以免错失后续更多实用的B端产品经理面试技巧!......
  • 菜品分页查询
    返回的一张表字段不全,得返回dto/***菜品信息分页查询*@parampage*@parampageSize*@paramname*@return*/@GetMapping......
  • Mybatis分页插件的原理
    首先分页参数放到ThreadLocal中,拦截执行的sql,根据数据库类型添加对应的分页语句重写sql,例如select*fromtablewherea转换为(根据数据库类型添加对应语句):selectcoun......
  • 制作房贷利息计算工具
    fromdecimalimportDecimalfrompickleimportGLOBALfromeasygui.boxes.derived_boxesimportenterboxfromprettytableimportPrettyTableimportcopy#fromd......
  • 分类信息分页查询
      /***分页查询*@parampage*@parampageSize*@return*/@GetMapping("/page")publicR<Page>page(intpage,intpag......