在thinkphp的框架下實現分頁。公司的網站基於Thinkphp框架,一直久聞thinkphp的大名,終於有機會實戰了。thinkphp是MVC架構的,MVC對於任何ITers來說都不陌生,模型(model)-視圖(view)-控制器(controller)。他將邏輯和數據分開處理,少了很多繁瑣的過程。其實在官方的資料中已經詳細的介紹了怎麼分頁,傳送門:http://document.thinkphp.cn/manual_3_2.html#data_page
可是並不適用於數據已經從DB中取出,並且轉換為數組的情況,我接觸PHP滿打滿算2個月,接觸thinkphp不過3周。之前把很多時間花在了官方文檔上,去熟悉thinkphp。也算是磨刀不誤砍柴工吧。這裡把官方文檔當作比較進行闡述:
(只舉文檔上第一個方法):利用Page類和limit方法,代碼如下:
復制代碼 代碼如下:
$User = M('User'); // 實例化User對象
$count= $User->where('status=1')->count();// 查詢滿足要求的總記錄數
$Page = new \Think\Page($count,25);// 實例化分頁類 傳入總記錄數和每頁顯示的記錄數(25)
$show = $Page->show();// 分頁顯示輸出
// 進行分頁數據查詢 注意limit方法的參數要使用Page類的屬性
$list = $User->where('status=1')->order('create_time')->limit($Page->firstRow.','.$Page->listRows)->select();
$this->assign('list',$list);// 賦值數據集
$this->assign('page',$show);// 賦值分頁輸出
$this->display(); // 輸出模板
基本思想就是先計算總的記錄數,然後根據所設置的每頁顯示的記錄數來分頁。使用Thinkphp封裝好的Page類可以很方便的實現。實現的重點在第11行,limit方法就是按照一定的規則從查詢數據中抽取數據。但是數據已經取出又怎麼辦呢?
我們用到了php自帶的函數array_slice( )。定義在此:http://www.php.net/manual/en/function.array-slice.php
其實就是數組版的limit方法。好了,工具找到了,實現就很容易了。直接上代碼:
復制代碼 代碼如下:
public function nodeslist(){
$portal = new PortalApi;
$nodelist = $portal->getNodeLists($this->uid);
$count = count($nodelist['data']);
$p = new Page($count,10);
$lists = array_slice($nodelist['data'], $p->firstRow,$p->listRows);
$page = $p->show();
$this->assign('page',$page);
$this->assign('nodes',$lists);
$this->display();
}
代碼有刪減,只保留實現細節。
第3行getNodeLists方法從數據庫中取出數據並賦值給數組nodelist。
第5行count計算出數組元素的個數。
第6行為Page類傳入參數。
第7行的array_slice函數代替了limit方法。原理相同。
第9行用assign方法為模版賦值。定義在此:http://document.thinkphp.cn/manual_3_2.html#assign
第10行同理。
下面是view中的代碼:
復制代碼 代碼如下:
<div class="page-list">
{$page}
</div>
如果僅僅這樣的話,顯示出來的效果並不友好。再找出來Page類的定義:
復制代碼 代碼如下:
// 分頁顯示定制
private $config= array(
'header' => '<span class="rows">共 %TOTAL_ROW% 條記錄</span>',
'prev' => '上一頁',
'next' => '下一頁',
'first'=> '第一頁',
'last' => '...%TOTAL_PAGE%',
'theme'=> '%FIRST% %UP_PAGE% %LINK_PAGE% %DOWN_PAGE% %END%',
在頁數前後加入空格。現在可以看效果了:
跟大背景還是挺配,當然,可以根據自己的情況設置不同的效果。