本文实例讲述了ThinkPHP3.2.3实现分页的方法。分享给大家供大家参考,具体如下:
首先要搞清楚的就是ThinkPHP3.2.3的分页类已经被移到了Think\Page.class.php,这是跟以前的版本有些不一样的,使用起来还是跟以前版本差不多,但是默认的效果不敢恭维,所以最好是自己加些样式。
我加了一些样式(不怎么好看),大家可以自行的再去改进分页样式,效果图:
在这里我有先把page的设置做成了一个函数getpage,将这个方法放到Application\Common\Common\function.php(注意function不是类)中方便其他地方调用,代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
<?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 ; } ?> |
控制器中使用的代码如下:
1
2
3
4
5
6
7
8
9
10
|
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中的使用:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
<!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,如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
.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框架的PHP程序设计有所帮助。