十天学会php之第八天
[b][color=#ff6600] [/color][/b]o`@.l)w7I J[font=宋体][size=10.5pt][color=#000000]学习目的:做一个分页显示[/color][/size][/font]]6yhR c,LxA(bX$L
[color=#000000][font=宋体][size=10.5pt]关键就是用到了[/size][/font]SQL[font=宋体][size=10.5pt]语句中的[/size][/font]limit[font=宋体][size=10.5pt]来限定显示的记录从几到几。我们需要一个记录当前页的变量[/size][/font]$page[font=宋体][size=10.5pt],还需要总共的记录数[/size][/font][/color][color=#000000]$num/cH2C5Mc%C
[font=宋体][size=10.5pt]对于[/size][/font]$page[font=宋体][size=10.5pt]如果没有我们就让它[/size][/font]=0[font=宋体][size=10.5pt],如果有[/size][/font]<0[font=宋体][size=10.5pt]就让它也[/size][/font]=0[font=宋体][size=10.5pt],如果超过了总的页数就让他[/size][/font]=[font=宋体][size=10.5pt]总的页数。[/size][/font][/color]:[(b/C!OaK7a!C og
[color=#000000]$execc="select count(*) from tablename ";5BNH(d+M7Q j'R!@6m
$resultc=mysql_query($execc);
$rsc=mysql_fetch_array($resultc);
$num=$rsc[0];
[/color][font=宋体][size=10.5pt][color=#000000]这样可以得到记录总数[/color][/size][/font] ZV1c!C8O b/Py;e
[color=#000000]ceil($num/10))[/color][color=#000000][font=宋体][size=10.5pt]如果一页[/size][/font]10[font=宋体][size=10.5pt]记录的话,这个就是总的页数[/size][/font][/color];O2K"T n z[!a
[font=宋体][size=10.5pt][color=#000000]所以可以这么写[/color][/size][/font] C%w&Aw:Zp;^s%^8W3B
[color=#000000]if(empty($_GET['page']))(h7mg@!]p7B
{ y8IS.Hvw5kc
$page=0;{8[(e4Xd7Q
}
elseTi-^%i"YK
{7O j-\Ps"N}L
$page=$_GET['page'];5Xi(MYo(C
if($page<0)$page=0;
if($page>=ceil($num/10))$page=ceil($num/10)-1;//[/color][color=#000000][font=宋体][size=10.5pt]因为[/size][/font]page[font=宋体][size=10.5pt]是从[/size][/font]0[font=宋体][size=10.5pt]开始的,所以要[/size][/font][/color][color=#000000]-1
}
[font=宋体][size=10.5pt]这样[/size][/font]$exec[font=宋体][size=10.5pt]可以这么写[/size][/font][/color][color=#000000] $exec="select * from tablename limit ".($page*10).",10";
//[font=宋体][size=10.5pt]一页是[/size][/font]10[font=宋体][size=10.5pt]记录的[/size][/font][/color]
[font=宋体][size=10.5pt][color=#000000]最后我们需要做的就是几个连接:[/color][/size][/font]Lp| q Q.Y N
[color=#000000]<a href="xxx.php?page=0">FirstPage</a> 5c`dg8W*B8f
<a href="xxx.php?page=<?=($page-1)?>">PrevPage</a>
<a href="xxx.php?page=<?=($page 1)?>">NextPage</a> 4PQT[Y!G
<a href="xxx.php?page=<?=ceil($num/10)-1?>">LastPage</a>t+kL}V;S aE
[/color][color=#000000][font=宋体][size=10.5pt]这是一个大致的思路,大家可以想想怎么来优化?十天学会[/size][/font]php[font=宋体][size=10.5pt]之第八天就说到这里,第九天说一下一些注意的问题。[/size][/font][/color]
页:
[1]