php页面分页类通用

分页显示是我们常常需要用到的,所以我为大家写了一个分页类,大家只用导入相应的项目就可以使用了!

Page.class.php

<?php

class Page {


    private $total; //数据表中总记录数
    private $listRows; //每页显示行数
    private $limit;
    private $uri;
    private $pageNum; //页数
    private $config = array('header' => "个记录", "prev" => "上一页", "next" => "下一页", "first" => "首 页", "last" => "尾 页");
    private $listNum = 8;


    /*
     * $total 总页数
     * $listRows 每页的条数
     */


    public function __construct($total, $listRows = 10, $pa = "") {
        $this->total = $total;
        $this->listRows = $listRows;
        $this->uri = $this->getUri($pa);
        $this->page = !empty($_GET["page"]) ? $_GET["page"] : 1;
        $this->pageNum = ceil($this->total / $this->listRows);
        $this->limit = $this->setLimit();
    }


    private function setLimit() {
        return "Limit " . ($this->page - 1) * $this->listRows . ", {$this->listRows}";
    }


    private function getUri($pa) {
        $url = $_SERVER["REQUEST_URI"] . (strpos($_SERVER["REQUEST_URI"], '?') ? '' : "?") . $pa;
        $parse = parse_url($url);






        if (isset($parse["query"])) {
            parse_str($parse['query'], $params);
            unset($params["page"]);
            $url = $parse['path'] . '?' . http_build_query($params);
        }


        return $url;
    }


    function __get($args) {
        if ($args == "limit")
            return $this->limit;
        else
            return null;
    }


    private function start() {
        if ($this->total == 0)
            return 0;
        else
            return ($this->page - 1) * $this->listRows + 1;
    }


    private function end() {
        return min($this->page * $this->listRows, $this->total);
    }


    private function first() {
        $html = "";
        if ($this->page == 1)
            $html.='';
        else
            $html.="&nbsp;&nbsp;<a href='{$this->uri}&page=1'>{$this->config["first"]}</a>&nbsp;&nbsp;";


        return $html;
    }


    private function prev() {
        $html = "";
        if ($this->page == 1)
            $html.='';
        else
            $html.="&nbsp;&nbsp;<a href='{$this->uri}&page=" . ($this->page - 1) . "'>{$this->config["prev"]}</a>&nbsp;&nbsp;";


        return $html;
    }


    private function pageList() {
        $linkPage = "";


        $inum = floor($this->listNum / 2);


        for ($i = $inum; $i >= 1; $i--) {
            $page = $this->page - $i;


            if ($page < 1)
                continue;


            $linkPage.="&nbsp;<a href='{$this->uri}&page={$page}'>{$page}</a>&nbsp;";
        }


        $linkPage.="&nbsp;{$this->page}&nbsp;";




        for ($i = 1; $i <= $inum; $i++) {
            $page = $this->page + $i;
            if ($page <= $this->pageNum)
                $linkPage.="&nbsp;<a href='{$this->uri}&page={$page}'>{$page}</a>&nbsp;";
            else
                break;
        }


        return $linkPage;
    }


    private function next() {
        $html = "";
        if ($this->page == $this->pageNum)
            $html.='';
        else
            $html.="&nbsp;&nbsp;<a href='{$this->uri}&page=" . ($this->page + 1) . "'>{$this->config["next"]}</a>&nbsp;&nbsp;";


        return $html;
    }


    private function last() {
        $html = "";
        if ($this->page == $this->pageNum)
            $html.='';
        else
            $html.="&nbsp;&nbsp;<a href='{$this->uri}&page=" . ($this->pageNum) . "'>{$this->config["last"]}</a>&nbsp;&nbsp;";


        return $html;
    }


    private function goPage() {
        return '&nbsp;&nbsp;<input type="text" οnkeydοwn="javascript:if(event.keyCode==13){var page=(this.value>' . $this->pageNum . ')?' . $this->pageNum . ':this.value;location=\'' . $this->uri . '&page=\'+page+\'\'}" value="' . $this->page . '" style="width:25px"><input type="button" value="GO" οnclick="javascript:var page=(this.previousSibling.value>' . $this->pageNum . ')?' . $this->pageNum . ':this.previousSibling.value;location=\'' . $this->uri . '&page=\'+page+\'\'">&nbsp;&nbsp;';
    }


    function fpage($display = array(0, 1, 2, 3, 4, 5, 6, 7, 8)) {
        $html[0] = "&nbsp;&nbsp;共有<b>{$this->total}</b>{$this->config["header"]}&nbsp;&nbsp;";
        $html[1] = "&nbsp;&nbsp;每页显示<b>" . ($this->end() - $this->start() + 1) . "</b>条,本页<b>{$this->start()}-{$this->end()}</b>条&nbsp;&nbsp;";
        $html[2] = "&nbsp;&nbsp;<b>{$this->page}/{$this->pageNum}</b>页&nbsp;&nbsp;";


        $html[3] = $this->first();
        $html[4] = $this->prev();
        $html[5] = $this->pageList();
        $html[6] = $this->next();
        $html[7] = $this->last();
        $html[8] = $this->goPage();
        $fpage = '';
        foreach ($display as $index) {
            $fpage.=$html[$index];
        }


        return $fpage;
    }


}

/***************************************************************************************************************************************/

导入使用

<?php
 require_once './Page.class.php';//这里导入该类
 $link=mysql_connect("127.0.0.1","root","");
       mysql_select_db('dh');
       mysql_query("set names 'utf8'");
 $result  =  mysql_query ( "SELECT * FROM serve" ,  $link );
 $total  =  mysql_num_rows ( $result );
 $per=2;
 $page1 = new  Page($total, $per);
 echo $page = $page1 -> fpage();
?>

以下是显示的结果:





  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
<?php /** * @name Pager's class * @author Refer * @copyright www.tsingyuan.cn * @version Alpha 1.0 * @todo 下拉菜单分页---From表单传值...可以根据自己的情况(采用GET传值) * */ class Pager{ /** * startRow * * @var Int */ public $startRow; /** * 页面的总数 * * @var Int */ public $pageTotal; /** *翻页值 * * @var Int */ public $offset; /** * 每页所显示记录数 * * @var Int */ public $pageSize; /** * get参数 * * @var Int */ public $get; /** * post参数 * * @var Int */ public $post; /** * 构造函数--初始化翻页类 (PS:^_^不错的php学习交流群:276167802,验证:ttf,有兴趣的话可以加入进来一起讨论) * * @param Int $total * @param Int $pageSize */ public function __construct($total,$pageSize){ $this->get = (int)$_GET['startRow']; $this->post = (int)$_POST['pageNums']; $this->pageSize = $pageSize; $this->pageTotal = ceil($total / $pageSize); switch ($_GET['method']){ default: $this->startRow = 1; $this->offset = 0; break; case 'first': $this->first(); break; case 'previous': $this->previous(); break; case 'next': $this->next(); break; case 'last': $this->last(); break; } } /** * 首页方法 * */ public function first(){ $this->startRow = 1; $this->offset = ($this->startRow - 1) * $this->pageSize; } /** * 上一页方法 * */ public function previous(){ $this->startRow = $this->get - 1; if ($this->startRow < 1) { $this->startRow = 1; } $this->offset = ($this->startRow - 1) * $this->pageSize; } /** * 下一页方法 * */ public function next(){ $this->startRow = $this->get + 1; if ($this->startRow > $this->pageTotal) { $this->startRow = $this->pageTotal; } $this->offset = ($this->startRow - 1) * $this->pageSize; } /** * 最后页方法 * */ public function last(){ $this->startRow = $this->pageTotal; $this->offset = ($this->startRow - 1) * $this->pageSize; } /** * 下拉菜单翻页 * * @return Int */ public function numPages(){ if ($this->post) { $pageNums = "<option>$this->post</option>"; $this->startRow = $this->post; $this->offset = ($this->post - 1) * $this->pageSize; } for ($i = 1; $i <= $this->pageTotal;$i++){ if ($i != $this->post) { $pageNums .= "<option>$i</option>"; } } return $pageNums; } /** * 当前是第几页 * * @return Int */ public function noncePage(){ if ($this->post) { return $this->startRow = $this->post; } else { return $this->startRow = $this->startRow; } } } 调用方法: [php] $total = $total->total();//总记录 $pageSize = 15;//每页显示的记录 $pager = new Pager($total,$pageSize); if ($pager->post){$startRow = $pager->noncePage();} $startRow = $pager->startRow; $pager->numPages(); $article->query("SELECT * FROM `categories` as c,`articles` as n WHERE c.id = n.pid ORDER BY n.id DESC LIMIT $pager->offset,$pageSize"); while ($article->fetchArray()) { $article->data['content'] = mb_substr(strip_tags($article->data['content']),0,40,'utf-8'); $articleIndex[] = $article->data; } $article->free(); } else { header("location:?act=login"); } $view->view->assign('startRow',$startRow);//caption $view->view->assign('total',$total);//caption $view->view->assign('pageNums',$pager->numPages());//pageNums $view->view->assign('noncePage',$pager->noncePage());//pageNums $view->view->assign('pageTotal',$pager->pageTotal);//pageTotal 模板页面: [php] <!--{if $pageTotal > 1}--> <form action="" method="post"> <div id="projectpages" class="fontpage"> Pager: <select name="pageNums" onchange="javascript:submit();" style="height:20px;"> <!--{$numPages}--> </select> <a href="?act=blog&method=first&startRow=<!--{$startRow}-->">First</a> <a href="?act=blog&method=previous&startRow=<!--{$startRow}-->">Previous</a> <a href="?act=blog&method=next&startRow=<!--{$startRow}-->">Next</a> <a href="?act=blog&method=last&startRow=<!--{$startRow}-->">Last</a> </div> </form> <!--{/if}-->

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值