ホームページ >php教程 >php手册 >ADODBとSMARTYを組み合わせたページングクラス

ADODBとSMARTYを組み合わせたページングクラス

WBOY
WBOYオリジナル
2016-06-21 09:05:452167ブラウズ

ado|ページネーション

/*
+-------------------------------------- ----------------------------------+
| 著者: Yitiankongyi (旧名: Yidai Network)
| : www.phpwb.com www.esdwl.com
| -------------------------------------- ------------- +
*/
class show_Pager
{
protected $_total; //レコードの総数
protected $pagesize; //各ページに表示されるレコード数
$_ページ番号
$offset; $pager_Links; 自由に変更できます

パブリック関数 __construct($total ,$pagesize ,$_cur_page)
r();
$ this->cur_page($_cur_page);
this‐>cur_page ($) ->_total/$this->pagesize);
}


public function cur_page($_cur_page) // ページ数を設定
{
if (isset($_cur_page) )
{
=intval($_cur_page);
$this->_cur_page;
}

//データベース レコード バイアス オフセット
public function _offset()
{
return $this->offset=$this- >pagesize*($this->_cur_page-1);
}

//HTML 接続タグ
public function link()
             $this->pager_Links = "首页 | 上一页 | 下一页 | 尾页";
}
elseif ($this->_cur_page > 1 && $this->_cur_page < ;= $this->pages)
{
//中间
$this->pager_Links = "首页 | 上一页 次页a href=".$PHP_SELF."?pager=$this->pages>尾< /a>";
}
return $this->pager_Links;
}

//html 数字连接标签
public function num_link()
{
$setpage = >_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.' '.$this->pagesize.'个/页 ';
if ($this->_cur_page > 1) {
$text .= ' [1]..';
}
if ($setpage > 1) {
$lastsetid = ($setpage-1)*$this->pernum;
$text .= '< a title=上一列 href=?pager='.$lastsetid.'>[<<]';
}
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).']< ;/b>';
} 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->ページ)
$text .= '[>>]';
{
ページ.']';
}
ADSC 同様に、$pager_size はページごとの表示数、$pager は現在のページです
//戻った後にテンプレートで直接使用できます
<{section name=sec ループ=$show}> <{/section} >
<{$numlink}>
class my_Pager extends show_Pager
{
function __construct($table,$where,$order,$pager_size) ,$pager)
{
global $conn;
global $ TPL; s $ SQL = "select * from` $ TABLE `$ when or order desc"
$ nums = $ conn-gt; & GT; = 新しい show_pager ($nums,$pager_size,$pager);
$show=$conn->SelectLimit($sql,$pager_size,$pager->offset())->GetAll();
$ tpl-&gt;





声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。