码迷,mamicode.com
首页 > Web开发 > 详细

thinkphp分页封装

时间:2018-05-10 15:43:44      阅读:195      评论:0      收藏:0      [点我收藏+]

标签:nbsp   sign   数据库   首页   ++   col   lang   ini   stat   

php

1.在think目录下新建文件Page.php

2.写如分页封装

  1 <?php
  2 /**
  3  * Created by PhpStorm.
  4  * User: Administrator
  5  * Date: 2018/5/8
  6  * Time: 18:02
  7  */
  8 
  9 namespace think;
 10 use think\Db;
 11 /**
 12  * 分页封装
 13  * */
 14 class Page
 15 {
 16     /**
 17      * 每页显示的条数
 18      * */
 19     private static $pageum = 5;
 20 
 21     /**
 22      * 每页显示的页码数
 23      * */
 24     private static $page_show = 5;
 25 
 26     /**
 27      * 当前页
 28      * */
 29     private static $page;
 30 
 31     /**
 32      * 跳转的链接 @@ $link @@
 33      * */
 34 
 35     /**
 36      * 数据库 @@ $surface @@
 37      * */
 38 
 39     public static function mypage($link,$surface){
 40         /*判断是否有页码传入*/
 41         if(empty(input(‘page‘))){
 42             self::$page = 1;
 43         }else{
 44             self::$page = input(‘page‘);
 45         }
 46         /*查询当前页数据*/
 47         $sql = Db::query("select * from $surface order by time desc limit ".(self::$page-1)*self::$pageum.",". self::$pageum);
 48         /* 查询数据总条数 $to_page */
 49         $r = Db::table($surface)->select();
 50         $to_page = count($r);
 51         /* 查询总页数 $result*/
 52         $result = ceil($to_page/self::$pageum);
 53         /**
 54          * 打印 首页 上一页
 55          */
 56         $page_print = ‘‘;//$page_print的默认值为空
 57         $home = 1;//第一页(首页)
 58         if(self::$page<=1){
 59             $page_print .= "<a href=$link$home>首页</a>";
 60             $page_print .= "<a href=$link$home><span>上一页</span></a>";
 61         }else{
 62             $page_print .= "<a href=$link$home>首页</a>";
 63             $page_print .= "<a href=$link".(self::$page-1)."><span>上一页</span></a>";
 64         }
 65         /**
 66          * 定义偏移量
 67          */
 68         /*初始化默认值(判断显示页码数是基数还是偶数)*/
 69 
 70         if((self::$page_show%2)==0){
 71             $offset = (self::$page_show)/2;//偏移量
 72             $start = self::$page-($offset-1);//左偏移
 73             $end = self::$page+$offset;//右偏移
 74         }else{
 75             /*基数*/
 76             $offset = (self::$page_show-1)/2;//偏移量
 77             $start = self::$page-$offset;//左偏移
 78             $end = self::$page+$offset;//右偏移
 79         }
 80         /*当前页码为2时*/
 81         if(self::$page <= 2){
 82             $start = 1;
 83             $end = self::$page_show;
 84         }
 85         /*当页页码大于最大页码时*/
 86         if(self::$page >= $result-$offset){
 87             $start = $result-self::$page_show+1;
 88             $end = $result;
 89         }
 90         /*当前页码小于显示页码时*/
 91         if($result<self::$page_show){
 92             $start = 1;
 93             $end = $result;
 94         }
 95         /**
 96          * 循环打印页码
 97          */
 98         //如果最大页数大于要显示的页数的时候
 99         if($result<self::$page_show){
100             for($i=1;$i<=$result;$i++){
101                 if($i == self::$page){
102                     $page_print .= "<a class=‘active‘>{$i}</a>";
103                 }else{
104                     $page_print .= "<a href=$link$result>{$i}</a>";
105                 }
106             }
107         }else{
108             for($i=$start;$i<=$end;$i++){
109                 if($i == self::$page){
110                     $page_print .= "<a class=‘active‘>{$i}</a>";
111                 }else{
112                     $page_print .= "<a href=$link$i>{$i}</a>";
113                 }
114             }
115         }
116         /**
117          * 打印 尾页 下一页
118          */
119         if(self::$page >= $result){
120             $page_print .= "<a href=$link$result><span>下一页</span></a>";
121             $page_print .= "<a href=$link$result>尾页</a>";
122         }else{
123             $page_print .= "<a href=$link".(self::$page+1)."><span>下一页</span></a>";
124             $page_print .= "<a href=$link$result>尾页</a>";
125         }
126         return array(‘page_print‘=>$page_print,‘to_page‘=>$to_page,‘sql‘=>$sql);
127     }
128 }

3.在想引用分页的PHP文件中引入

use think\Page;

4.调用静态类传入地址和数据库

$data = Page::mypage(‘地址后面接上?page=‘,‘数据库‘);

5.取出数据

$result = $data[‘sql‘];

6.取出分页

$page = $data[‘page‘];

7.把数据传入前端页面展示出来

$this->assign(‘result‘,$result);
$this->assign(‘page‘,$page);

html页面

 

<!DOCTYPE html>
<html lang="en">
    <head>
    </head>
    <body>
        {volist name="result" id="v"}
            数据
        {/volist}
        {$page}
    </body>
</html>            

 

最后根据所给类名设置css样式

里面页码和显示数据条数都是可以自己设置

 

thinkphp分页封装

标签:nbsp   sign   数据库   首页   ++   col   lang   ini   stat   

原文地址:https://www.cnblogs.com/notesbooks/p/9019579.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!