本文實例講述了ThinkPHP3.2.3實現分頁的方法。分享給大家供大家參考,具體如下:
首先要搞清楚的就是ThinkPHP3.2.3的分頁類已經被移到了Think\Page.class.php,這是跟以前的版本有些不一樣的,使用起來還是跟以前版本差不多,但是默認的效果不敢恭維,所以最好是自己加些樣式。
我加了一些樣式(不怎麼好看),大家可以自行的再去改進分頁樣式,效果圖:
在這裡我有先把page的設置做成了一個函數getpage,將這個方法放到Application\Common\Common\function.php(注意function不是類)中方便其他地方調用,代碼如下:
<?php /** * TODO 基礎分頁的相同代碼封裝,使前台的代碼更少 * @param $count 要分頁的總記錄數 * @param int $pagesize 每頁查詢條數 * @return \Think\Page */ function getpage($count, $pagesize = 10) { $p = new Think\Page($count, $pagesize); $p->setConfig('header', '<li class="rows">共<b>%TOTAL_ROW%</b>條記錄 第<b>%NOW_PAGE%</b>頁/共<b>%TOTAL_PAGE%</b>頁</li>'); $p->setConfig('prev', '上一頁'); $p->setConfig('next', '下一頁'); $p->setConfig('last', '末頁'); $p->setConfig('first', '首頁'); $p->setConfig('theme', '%FIRST%%UP_PAGE%%LINK_PAGE%%DOWN_PAGE%%END%%HEADER%'); $p->lastSuffix = false;//最後一頁不顯示為總頁數 return $p; } ?>
控制器中使用的代碼如下:
public function showAllUsers() { $m = M('User'); $where = "id>10"; $count = $m->where($where)->count(); $p = getpage($count,1); $list = $m->field(true)->where($where)->order('id')->limit($p->firstRow, $p->listRows)->select(); $this->assign('select', $list); // 賦值數據集 $this->assign('page', $p->show()); // 賦值分頁輸出 $this->display(); }
接下來在View中的使用:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>用戶信息輸出</title> <link href="__ROOT__/Public/Css/style.css" rel="stylesheet" type="text/css" /> <link href="__ROOT__/Public/Css/mypage.css" rel="stylesheet" type="text/css"/> </head> <body> <table width="405" border="1" cellpadding="1" cellspacing="1" bgcolor="#99CC33" bordercolor="#FFFFFF"> <tr> <td colspan="3" bgcolor="#FFFFFF" class="title" align="center">當前登錄用戶:{$Think.session.admin}</td> </tr> <tr> <td colspan="3" bgcolor="#FFFFFF" class="title" align="center">用戶信息</td> </tr> <tr class="title"> <td bgcolor="#FFFFFF" width="44">ID</td> <td bgcolor="#FFFFFF" width="120">用戶名</td> <td bgcolor="#FFFFFF" width="223">密碼</td> </tr> <foreach name='select' item='user' > <tr class="content"> <td bgcolor="#FFFFFF"> {$user.id}</td> <td bgcolor="#FFFFFF"> {$user.account}</td> <td bgcolor="#FFFFFF"> {$user.pwd}</td> </tr> </foreach> <tr class="content"> <!--<td colspan="3" bgcolor="#FFFFFF"> {$page}</td>--> <td colspan="3" bgcolor="#FFFFFF"><div class="pages"> {$page} </div></td> </tr> </table> </body> </html>
其中設置分頁的樣式mypage.css,如下:
.pages a,.pages span { display:inline-block; padding:2px 5px; margin:0 1px; border:1px solid #f0f0f0; -webkit-border-radius:3px; -moz-border-radius:3px; border-radius:3px; } .pages a,.pages li { display:inline-block; list-style: none; text-decoration:none; color:#58A0D3; } .pages a.first,.pages a.prev,.pages a.next,.pages a.end{ margin:0; } .pages a:hover{ border-color:#50A8E6; } .pages span.current{ background:#50A8E6; color:#FFF; font-weight:700; border-color:#50A8E6; }
這樣就可以了。
更多關於thinkPHP相關內容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《ThinkPHP常用方法總結》、《PHP中cookie用法總結》、《smarty模板入門基礎教程》及《PHP模板技術總結》。
希望本文所述對大家基於ThinkPHP框架的PHP程序設計有所幫助。