本文实例讲述了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程序设计有所帮助。