样式:

a{
text-decoration: none;
color: inherit;
}
.out-cp{
width:100%;
text-align: center;
}
.c-page{
display:inline-block;
height:42px;
margin:50px 0 ;
}
.c-page > div{
float: left;
height:42px;
}
.c-page > div:not(:first-child){
margin-left: 10px;
}
.c-page > div > a{
height:40px;
display: block;
border-top: solid 1px #e5e5e5;
border-right:solid 1px #e5e5e5;
border-bottom:solid 1px #e5e5e5;
float: left;
font-size: 14px;
letter-spacing: 1px;
color: #333333;
text-align: center;
line-height: 40px;
}
.c-page > div > a:hover,.c-page > div > a.on{
color: #ffffff;
background-color: #699dff;
border-color:#699dff; ;
}
.c-page > div > a:nth-child(1){
border-left: solid 1px #e5e5e5;
}
.c-page > .c-page-lefts > a:nth-child(1),.c-page > .c-page-rights > a:nth-child(2){
width: 50px;
} .c-page > .c-page-lefts > a:nth-child(2),.c-page > .c-page-rights > a:nth-child(1){
width: 80px;
}
.c-page > .c-page-middles > a{
width: 40px;
} .c-page > div > a:nth-child(1){
border-radius: 4px 0px 0px 4px;
}
.c-page > div > a:last-child{
border-radius: 0px 4px 4px 0px;
} .c-page > .c-page-lefts > a:nth-child(2):before,.c-page > .c-page-rights > a:nth-child(1):after{
content: '';
display: inline-block;
width:7px;
height:12px;
position: relative;
top:1px;
}
.c-page > .c-page-lefts > a:nth-child(2):before{
background: url("http://www.yangqu.com/images/ccpageb.png")center center no-repeat;
margin-right: 5px;
}
.c-page > .c-page-rights > a:nth-child(1):after{
background: url("http://www.yangqu.com/images/ccpageb.png")center center no-repeat;
margin-left: 5px;
transform:rotate(180deg);
}
.c-page > .c-page-lefts > a:nth-child(2):hover:before{
background: url("http://www.yangqu.com/images/ccpagea.png")center center no-repeat;
}
.c-page > .c-page-rights > a:nth-child(1):hover:after{
background: url("http://www.yangqu.com/images/ccpagea.png")center center no-repeat;
transform:rotate(180deg);
} .c-page > .c-page-lefts > a:nth-child(2).dis:before{
background: url("http://www.yangqu.com/images/ccpagec.png")center center no-repeat;
} .c-page > .c-page-rights > a:nth-child(1).dis:after{
background: url("http://www.yangqu.com/images/ccpagec.png")center center no-repeat; transform:rotate(180deg);
} .c-page > div > a.dis{
background-color: #FBFBFB;
color: #C9C9C9;
cursor: not-allowed;
border-color: #e5e5e5;
}

逻辑:

/*

 * 接收sql语句,获取列表以及分页

 */

function cPage($sql,$pageSize = 10){
global $db; //分页要素:pageNow 、 pageSize /* * 编辑sql语句查询count */ $csql =preg_replace("/SELECT.*FROM/i" , 'SELECT COUNT(*) FROM',$sql); $res = $db->fetch_array($db->query($csql)); $item_count = $res['COUNT(*)']; $pageCount = intval($item_count / $pageSize) + ($item_count % $pageSize > 0 ? 1 : 0); /* * 接受并且检测pageNow * 1:若 pageNow 不为正整数,则 pageNow = 1 * 2: 若 pageNow 大于 $pageCount ,则 $pageNow = $pageCount; */ $pageNow = (preg_match("/^[1-9][0-9]*$/",$_GET['pageNow'])) ? $_GET['pageNow'] : 1;
var_dump($pageNow);
$pageNow = $pageNow > $pageCount ? $pageCount : $pageNow; $offset = ($pageNow - 1) * $pageSize; $data = []; $sql .= " LIMIT $offset,$pageSize"; $result = $db->query($sql); while($r = $db->fetch_array($result)){ $data[] = $r; } //生成[get] param $paramData = $_GET; $paramStr = '?'; $flag_1 = 0; foreach ($paramData as $k => $v){ // .. if($k == 'pageNow'){ continue; } if($flag_1 > 0){ $paramStr .= '&'; } $paramStr .= "$k=$v"; $flag_1 ++; } if(!$flag_1){ $paramStr .= "pageNow="; }else{ $paramStr .= "&pageNow="; } // html $html = '<div class="out-cp"> <div class="c-page">'; $html .= ' <div class="c-page-lefts"> <a href="'.($paramStr . 1).'">首页</a>'; /* * 上一页。两种情况: * true : 当前不为第一页 且 pageCount > 1 * false : the else */ if($pageNow > 1 && $pageCount > 1 ){ $html .= ' <a href="'.$paramStr . ($pageNow - 1).'">上一页</a>'; }else{ $html .= ' <a class="dis">上一页</a>'; } $html .= "</div>"; /* * mid * 最多显示7个页码,且当前页优先位于最中间 */ $midPage = []; if($pageCount > 7){ // left.. if(($pageNow - 3 ) < 1){ $midPage = range(1,7); } // .. else if( ($pageCount - $pageNow) < 3){ $midPage = range($pageCount - 6,$pageCount); } else{ $midPage = range($pageNow - 3,$pageNow + 3); } }else{ if($pageCount > 0){ $midPage = range(1,$pageCount); }else{ $midPage = []; } } $html .= '<div class="c-page-middles">'; foreach ($midPage as $k_1 => $v_2){ // selected if($v_2 == $pageNow){ $html .= '<a class="on" href="'.$paramStr . $v_2 .'">'.$v_2.'</a>'; }else{ $html .= '<a href="'.$paramStr . $v_2 .'">'.$v_2.'</a>'; } } $html .= "</div>"; /* * 下一页;两种情况: * true : pageCount > pageNow * false : ..else.. */ $html .= '<div class="c-page-rights">'; if($pageCount > $pageNow){ $html .= '<a href="'.$paramStr . ($pageNow + 1).'">下一页</a>'; }else{ $html .= '<a class="dis">下一页</a>'; } $html .= ' <a href="'.$paramStr . $pageCount.'">尾页</a> </div> </div> </div>'; return ['data' => $data , 'pageCode' => $html]; }

/*
 * 接收sql语句,获取列表以及分页
 */

function cPage($sql,$pageSize = 10){    global $db;
    //分页要素:pageNow 、 pageSize

/*
     * 编辑sql语句查询count
     */
    $csql  =preg_replace("/SELECT.*FROM/i" , 'SELECT COUNT(*) FROM',$sql);
    $res = $db->fetch_array($db->query($csql));
    $item_count = $res['COUNT(*)'];
    $pageCount = intval($item_count / $pageSize) + ($item_count % $pageSize > 0 ? 1 : 0);

/*
     * 接受并且检测pageNow
     * 1:若 pageNow 不为正整数,则 pageNow = 1
     *  2: 若 pageNow 大于 $pageCount ,则 $pageNow = $pageCount;
     */
    $pageNow = (preg_match("/^[1-9][0-9]*$/",$_GET['pageNow'])) ? $_GET['pageNow'] : 1;    var_dump($pageNow);    $pageNow = $pageNow > $pageCount ? $pageCount : $pageNow;
    $offset = ($pageNow - 1) * $pageSize;
    $data = [];
    $sql .= " LIMIT $offset,$pageSize";
    $result = $db->query($sql);
    while($r = $db->fetch_array($result)){
        $data[] = $r;
    }

//生成[get] param
    $paramData = $_GET;
    $paramStr = '?';
    $flag_1 = 0;
    foreach ($paramData as $k => $v){
        // ..
        if($k == 'pageNow'){
            continue;
        }
        if($flag_1 > 0){
            $paramStr .= '&';
        }
        $paramStr .= "$k=$v";
        $flag_1 ++;
    }
    if(!$flag_1){
        $paramStr .= "pageNow=";
    }else{
        $paramStr .= "&pageNow=";
    }

// html
    $html = '<div class="out-cp">
                <div class="c-page">';
    $html .= '        <div class="c-page-lefts">
                            <a href="'.($paramStr . 1).'">首页</a>';
    /*
     * 上一页。两种情况:
     * true  : 当前不为第一页 且 pageCount > 1
     * false  :  the else
     */
    if($pageNow > 1  && $pageCount > 1 ){
        $html .= ' <a href="'.$paramStr . ($pageNow - 1).'">上一页</a>';
    }else{
        $html .= ' <a class="dis">上一页</a>';
    }
    $html .= "</div>";
    /*
     * mid
     * 最多显示7个页码,且当前页优先位于最中间
     */
    $midPage = [];

if($pageCount  > 7){
        // left..
        if(($pageNow - 3 ) < 1){
            $midPage = range(1,7);
        }
        // ..
        else if( ($pageCount - $pageNow) < 3){
            $midPage = range($pageCount - 6,$pageCount);
        }
        else{
            $midPage = range($pageNow - 3,$pageNow + 3);
        }
    }else{
        if($pageCount > 0){
            $midPage = range(1,$pageCount);
        }else{
            $midPage = [];
        }

}

$html .= '<div class="c-page-middles">';

foreach ($midPage as $k_1 => $v_2){
        // selected
        if($v_2 == $pageNow){
            $html .= '<a class="on" href="'.$paramStr . $v_2 .'">'.$v_2.'</a>';
        }else{
            $html .= '<a href="'.$paramStr . $v_2 .'">'.$v_2.'</a>';
        }
    }
    $html .= "</div>";

/*
     * 下一页;两种情况:
     * true : pageCount > pageNow
     * false : ..else..
     */
    $html .= '<div class="c-page-rights">';
    if($pageCount > $pageNow){
        $html .= '<a href="'.$paramStr . ($pageNow + 1).'">下一页</a>';
    }else{
        $html .= '<a  class="dis">下一页</a>';
    }
    $html .= '        <a href="'.$paramStr . $pageCount.'">尾页</a>
                        </div>
                            </div>
                                </div>';
    return ['data' => $data , 'pageCode' => $html];
}

一个仿tp5分页组件的实现的更多相关文章

  1. 基于iview 封装一个vue 表格分页组件

    iview 是一个支持中大型项目的后台管理系统ui组件库,相对于一个后台管理系统的表格来说分页十分常见的 iview是一个基于vue的ui组件库,其中的iview-admin是一个已经为我们搭好的后天 ...

  2. asp.net mvc4+mysql做一个简单分页组件(部分视图)

    在开始做mysql分页功能组件前,便设定的是要有一定可复用性.先在项目里Views文件夹下右键新建名为_PaginationComponent.cshtml,这里html及css我采用的bootstr ...

  3. 基于Vue.js的表格分页组件

    有一段时间没更新文章了,主要是因为自己一直在忙着学习新的东西而忘记分享了,实在惭愧. 这不,大半夜发文更一篇文章,分享一个自己编写的一个Vue的小组件,名叫BootPage. 不了解Vue.js的童鞋 ...

  4. javascript 分页组件

    自己写的一个简单的分页组件,主要功能还有实现都在JS中,html页面中只用增加一个放置生成分页的DIV,并给定容器的id. html结构如下: <ul class="paginatio ...

  5. Vue.js的表格分页组件

    转自:http://www.cnblogs.com/Leo_wl/p/5522299.html 有一段时间没更新文章了,主要是因为自己一直在忙着学习新的东西而忘记分享了,实在惭愧. 这不,大半夜发文更 ...

  6. 转载使用Flurl制作可复用的分页组件

    使用Flurl制作可复用的分页组件 使用ASP.NET MVC查询时,一直使用MvcPaging组件,虽然需要自定义MvcPaging.Pager才能达到我想要的效果,但在没有较好的URL库时,还是这 ...

  7. asp.net core 排序过滤分页组件:sieve(1)

    使用asp.net core开发时避免不了要用一个合适的分页组件来让前端获取分页数据.github上面有一个开源的分页组件在这方面很适合我的使用,于是我把他的文档翻译一下,随后会分析它里面的源码.这是 ...

  8. Angular4.+ ngx-bootstrap Pagination 自定义分页组件

    Angular4 随笔(二)  ——自定义分页组件 1.简介 本组件主要是实现了分页组件显示功能,通过使用 ngx-bootstrap Pagination分页组件实现. 基本逻辑: 1.创建一个分页 ...

  9. 基于 bootstrap 的 vue 分页组件

    申手党点这里下载示例 基于 bootstrap 的 vue 分页组件,我想会有那么一部分同学,在使用Vue的时候不使用单文件组件,因为不架设 NodeJS 服务端.那么网上流传的 *.vue 的各种分 ...

随机推荐

  1. 【巨杉数据库SequoiaDB】巨杉Tech | “删库跑路”又出现,如何防范数据安全风险?

    最近,又双叕有企业被“删库”了.来自微盟官网的消息,微盟的业务系统数据库(包括主备)遭遇其公司运维人员的删除,系统将停止运营超48小时. 频发的类似事件也让大家对于数据安全的关注不断提高.数据是一个科 ...

  2. XSS攻击解决办法 Spring mvc databinder

    XSS攻击解决办法 一.SpringMVC架构下@InitBinder方法 Controller方法的参数类型可以是基本类型,也可以是封装后的普通Java类型.若这个普通Java类型没有声明任何注解, ...

  3. SpringBoot原理—分析SpringBoot启动机制(starter机制)

    一:前言使用过springboot的同学应该已经知道,springboot通过默认配置了很多框架的使用方式帮我们大大简化了项目初始搭建以及开发过程.本文的目的就是一步步分析springboot的启动过 ...

  4. 安卓平台SQLite数据库基础操作总结

    最近学了一些安卓开发,在这里分享一下SQLite数据库的使用相关部分,我使用的工具为Android Studio,后台语言为java: 首先,需要创建一个数据库辅助类DataBaseHelper,用于 ...

  5. 安装Kibana到Linux(源码)

    运行环境 系统版本:CentOS Linux release 7.3.1611 (Core) 软件版本:Kibana-7.1.0 硬件要求:最低2核4GB 安装过程 1.源码安装JDK 1.1.从官网 ...

  6. 树莓派3b 换国内源 更新源

    在国内要更新源的时候,因为是国外的源,总会出现网速太慢的问题, 以下是对于安装了,2017-11-29-raspbian-stretch 系统源 更换最好用root登陆操作 sudo passwd r ...

  7. Npoi常用操作方法介绍

    1.ShiftRows(startRow,endRow,moveRows) 将开始行到结束行向上或者向下移动moveRows行,moveRows为正数向下移动,为负数向上移动(向上移动,会把之前的行覆 ...

  8. C语言实现顺序栈

    C语言实现顺序栈,顺便加深刻++i,++i的区别 #include <stdio.h>#include <stdlib.h>#define maxsize 100/*写在前面的 ...

  9. html css二级导航栏

    二级导航栏制作: 1.将一级导航栏去除列表样式(list-style:none),并给予浮动,使其横向排列(float:left) 2.给每个li中添加一个<a></a>标签, ...

  10. Windows Live Writer 2012 安装配置

    Windows Live Writer 2012用起来比较舒服,可以直接编辑 在线博客文章 下载地址 http://g.live.com/1rewlive5-all/zh-cn/wlsetup-all ...