ADODB和SMARTY結合的分頁類

日期:2006-08-07  作者:喜騰小二  來源:PHPChina


/*
+-----------------------------------------------------------------------+
| 作者:一天空一(曾用名:億時代網路)
| 網址:www.phpwb.com www.esdwl.com
| Q Q: 31769416
| 時間:2006-05-03                                 
|+-----------------------------------------------------------------------+
*/
    class show_Pager
    {
      protected  $_total;                          //記錄總數
      protected  $pagesize;                       //每一頁顯示的記錄數
      public     $pages;                         //總頁數
      protected  $_cur_page;                    //當前頁碼
      protected  $offset;                      //記錄偏移量
      protected  $pager_Links;                //url連線
      protected  $pernum = 5;                //頁碼偏移量,這裡可隨意變更
   
      public function __construct($total,$pagesize,$_cur_page)
        {   
        $this->_total=$total;
        $this->pagesize=$pagesize;
        $this->_offset();
        $this->_pager();
        $this->cur_page($_cur_page);
        $this->link();
    }
   
    public  function _pager()//計算總頁數
    {
    return $this->pages = ceil($this->_total/$this->pagesize);
    }
   
   
    public function cur_page($_cur_page) //設定頁數
    {     
               if (isset($_cur_page))
           {
           $this->_cur_page=intval($_cur_page);
           }
           else
           {
            $this->_cur_page=1; //設定為第一頁
           }
        return  $this->_cur_page;
   }
   
//資料庫記錄偏移量
   public function _offset()
   {
   return $this->offset=$this->pagesize*($this->_cur_page-1);
   }
   
  //html連線的選項卡
  public function link()
  {
    if ($this->_cur_page == 1 && $this->pages>1)
        {
            //第一頁
            $this->pager_Links = "首 頁 | 上一頁 | 下一頁 | pages>尾 頁";
        }
        elseif($this->_cur_page == $this->pages && $this->pages>1)
        {
            //最後一頁
             $this->pager_Links = "首 頁 | 上一頁 | 下一頁 | 尾 頁";
        }
        elseif ($this->_cur_page > 1 && $this->_cur_page <= $this->pages)
        {
            //中間
             $this->pager_Links = "首 頁 | 上一頁 | 下一頁 | pages>尾 頁";
        }
        return $this->pager_Links;
  }
  
  //html數字連線的選項卡
   public function num_link()
  {
       $setpage  = $this->_cur_page ? ceil($this->_cur_page/$this->pernum) : 1;
        $pagenum   = ($this->pages > $this->pernum) ? $this->pernum : $this->pages;
        if ($this->_total  <= $this->pagesize) {
            $text  = '隻有一頁';
        } else {
            $text = '頁數:'.$this->pages.'&nbsp;'.$this->pagesize.'個/頁&nbsp;';
            if ($this->_cur_page > 1) {
                $text .= '[1]..';
            }
            if ($setpage > 1) {
                $lastsetid = ($setpage-1)*$this->pernum;
                $text .= '[<<]';
            }
            if ($this->_cur_page > 1) {
                $pre = $this->_cur_page-1;
                $text .= '[<]';
            }
            $i = ($setpage-1)*$this->pernum;
            for($j=$i; $j<($i+$pagenum) && $j<$this->pages; $j++) {
                $newpage = $j+1;
                if ($this->_cur_page == $j+1) {
                    $text .= '['.($j+1).']';
                } else {
                    $text .= '['.($j+1).']';
                }
            }            
            if ($this->_cur_page < $this->pages){
                $next = $this->_cur_page+1;
                $text .= '[>]';
            }
            if ($setpage < $this->_total) {
                $nextpre = $setpage*($this->pernum+1);
                if($nextpre<$this->pages)
                $text .= '[>>]';
            }
            if ($this->_cur_page < $this->pages) {
                $text .= '..pages.'>['.$this->pages.']';
            }
         }
            return $text;
         }
    }
//$conn,$tpl 全域變數 傳入 $table是資料表 $where 是條件陳述式 $order 是ADSC之類的,$pager_size是每頁顯示數,$pager是當前頁
//返回後在摸闆裡麵可以直接使用
<{section name=sec loop=$show}>  <{/section}>數字選項卡用<{$numlink}>    class my_Pager extends show_Pager
    {
        function __construct($table,$where,$order,$pager_size,$pager)
        {
         global $conn;
         global $tpl;
         $sql="SELECT * FROM `$table` $where order by $order desc";
         $nums=$conn->Execute($sql)->RecordCount();
         $pager=new show_Pager($nums,$pager_size,$pager);
         $show=$conn->SelectLimit($sql,$pager_size,$pager->_offset())->GetAll();
         $tpl->assign("numlink",$pager->num_link());//數字選項卡
         $tpl->assign("show",$show);//顯示帖子
        }
    }
?>

<<<返回技術中心

技術文章

站內新聞

我要啦免费统计