thinkphp實現數組分頁樣本_PHP教程

來源:互聯網
上載者:User
在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中的代碼:

複製代碼 代碼如下:

{$page}



如果僅僅這樣的話,顯示出來的效果並不友好。再找出來Page類的定義:

複製代碼 代碼如下:
// 分頁顯示定製

private $config= array(

'header' => '共 %TOTAL_ROW% 條記錄',

'prev' => '上一頁',

'next' => '下一頁',

'first'=> '第一頁',

'last' => '...%TOTAL_PAGE%',

'theme'=> '%FIRST% %UP_PAGE% %LINK_PAGE% %DOWN_PAGE% %END%',

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

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

http://www.bkjia.com/PHPjc/754033.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/754033.htmlTechArticle在thinkphp的架構下實現分頁 。公司的網站基於Thinkphp架構,一直久聞thinkphp的大名,終於有機會實戰了。thinkphp是MVC架構的,MVC對於任何ITe...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.