<?php
class Page {
public $page; //當前頁
public $total; //總記錄數
public $listRows; //每頁顯示記錄數
private $uri;//動態url
public $pageNum; //總頁數
private $listNum=6;//顯示頁碼按鈕數量
public $render;//分頁后的html模板
public $data;//分頁后渲染到模板的數據
/*
* 初始化分頁數據
*$sdata 待分頁的數據
* $listRows 每頁記錄數
*/
public function __construct($sdata, $listRows=15){
$this->total=count($sdata);
$this->listRows=$listRows;
$this->uri=$this->getUri();
$this->page=!empty($_GET["page"]) ? $_GET["page"] : 1;
$this->pageNum=ceil($this->total/$this->listRows);
$this->render=$this->pageHtml();
$this->data=array_slice($sdata,($this->page-1)*$this->listRows,$listRows);
return $this->data;
}
//動態獲取url
private function getUri(){
$url=$_SERVER["REQUEST_URI"].(strpos($_SERVER["REQUEST_URI"], '?')?'':"?");
$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;
}
//首頁
private function first(){
$html = "";
if($this->page==1)
$html.=" <a style='magin=10px;' class='current btn disabled'>首 頁</a>";
else
$html.=" <a class='btn btn-primary-outline' href='{$this->uri}&page=1'>首 頁</a>";
return $html;
}
//上一頁
private function prev(){
$html = "";
if($this->page==1)
$html.=" <a class='current btn disabled'>上一頁</a>";
else
$html.=" <a class='btn btn-primary-outline' href='{$this->uri}&page=".($this->page-1)."'>上一頁</a>";
return $html;
}
//頁碼按鈕
private function pageList(){
$linkPage="";
$inum=floor($this->listNum/2);
for($i=$this->page-$inum;$i<=$this->page+$inum;$i++){
if($i<=0){
continue;
}
if($i>$this->pageNum){
continue;
}
if($i == $this->page){
$linkPage.=" <a class='current btn btn-secondary'>{$i}</a>";
}else{
$linkPage.=" <a class='btn btn-primary-outline' href='{$this->uri}&page={$i}'>{$i}</a>";
}
}
return $linkPage;
}
//下一頁
private function next(){
$html = "";
if($this->page==$this->pageNum)
$html.=" <a class='current btn disabled'>下一頁</a>";
else
$html.=" <a class='btn btn-primary-outline' href='{$this->uri}&page=".($this->page+1)."'>下一頁</a>";
return $html;
}
//尾頁
private function last(){
$html = "";
if($this->page==$this->pageNum)
$html.=" <a class='current btn disabled'>尾 頁</a>";
else
$html.=" <a class='btn btn-primary-outline' href='{$this->uri}&page=".($this->pageNum)."'>尾 頁</a>";
return $html;
}
//輸入指定頁碼
private function goPage(){
return ' <input class="input-text" type="text" onkeydown="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:52px"><input class="btn btn-secondary" type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>'.$this->pageNum.')?'.$this->pageNum.':this.previousSibling.value;location=\''.$this->uri.'&page=\'+page+\'\'"> ';
}
//選擇指定頁碼
function selectPage(){
$inum=10;
$location = $this->uri.'&page=';
$selectPage ="<span class='va-m'>到第 </span> <span class='select-box' style='width:initial'><select class='select' name='topage' size='1' onchange='window.location=\"$location\"+this.value'>";
for($i=$this->page-$inum;$i<=$this->page+$inum;$i++){
if($i<=0){
continue;
}
if($i>$this->pageNum){
continue;
}
if($i == $this->page){
$selectPage .="<option value='$i' selected>$i</option>";
}else{
$selectPage .="<option value='$i'>$i</option>";
}
}
$selectPage .="</select></span> <span class='va-m'>頁</span>";
return $selectPage;
}
//組裝分頁的html模板
function pageHtml(){
$html = "<div class='cl mt-20 text-c'>";
// $html .= "<span class='pr-20 va-m'>共有<b>{$this->total}</b>條記錄</span>";
// $html .= "<span class='pr-20 va-m'>每頁顯示<b>{$this->listRows}</b>條</span>";
// $html .= "<span class='pr-20 va-m'><b>當前{$this->page}/{$this->pageNum}</b>頁</span>";
$html .= $this->first();
$html .= $this->prev();
$html .= $this->pageList();
$html .= $this->next();
$html .= $this->last();
$html .= $this->goPage();
$html .= $this->selectPage();
$html .= '</div>';
return $html;
}
}
使用方法:在控制器中調用這個擴展類,new一個分頁對象$p,並渲染到模板
//$data:array,通過select()查詢未分頁的數據,不能是已經分頁的對象
$data = db('table_name')->select();
//$data:未分頁的數據 2:每頁顯示的記錄數
$p = new \Page($data,2);
//把分頁后的對象$p渲染到模板
$this->assign([
'p' => $p,
]);
return $this->fetch();
使用方法:最后在模板中使用這個分頁后的對象$p,通過$p->屬性,獲取對應的數據
//$p->data; //當前頁數據
//$p->render; 分頁html模板
//$p->page; //當前第幾頁
//$p->total; //總記錄數
//$p->listRows; //每頁顯示記錄數
//$p->pageNum; //總頁數
//根據需要組裝數據輸出顯示,例如:
//遍歷數據
{volist name='$p->data' id='vo'}
//code...
{/volist}
//分頁html模板輸出
//默認已經載入h-ui框架css樣式,否則需要重寫css樣式
{$p->render}
注意:支持URL模式,模塊/控制器/操作?參數名=參數值&...