程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> thinkphp實現數組分頁示例

thinkphp實現數組分頁示例

編輯:關於PHP編程

在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%',

在頁數前後加入空格。現在可以看效果了:

跟大背景還是挺配,當然,可以根據自己的情況設置不同的效果。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved