十天学会php之第八天
[b][color=#ff6600] [/color][/b][font=宋体][size=10.5pt][color=#000000]学习目的:做一个分页显示[/color][/size][/font]
[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]$numZ8Ml+|/e
[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]eW!j?k3F/V
[color=#000000]$execc="select count(*) from tablename ";
$resultc=mysql_query($execc);0s6x'uO{Ht
$rsc=mysql_fetch_array($resultc);:Rb M@ qQq.z3V{
$num=$rsc[0];
[/color][font=宋体][size=10.5pt][color=#000000]这样可以得到记录总数[/color][/size][/font]@W/jl2? `
[color=#000000]ceil($num/10))[/color][color=#000000][font=宋体][size=10.5pt]如果一页[/size][/font]10[font=宋体][size=10.5pt]记录的话,这个就是总的页数[/size][/font][/color]e"kA8Auy#U
[font=宋体][size=10.5pt][color=#000000]所以可以这么写[/color][/size][/font]
[color=#000000]if(empty($_GET['page']))
{
$page=0;
}
else
{+VF'P-C;Cy,t5d#e
$page=$_GET['page'];
if($page<0)$page=0;,R{S:f+I f3j?y
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,b"J2DPJ`0[I
}
[font=宋体][size=10.5pt]这样[/size][/font]$exec[font=宋体][size=10.5pt]可以这么写[/size][/font][/color][color=#000000] $exec="select * from tablename limit ".($page*10).",10";o'SjNBTrd
//[font=宋体][size=10.5pt]一页是[/size][/font]10[font=宋体][size=10.5pt]记录的[/size][/font][/color]y9P.y6a3big_q?
[font=宋体][size=10.5pt][color=#000000]最后我们需要做的就是几个连接:[/color][/size][/font]
[color=#000000]<a href="xxx.php?page=0">FirstPage</a>
<a href="xxx.php?page=<?=($page-1)?>">PrevPage</a> 'G]jsk:oTQb
<a href="xxx.php?page=<?=($page 1)?>">NextPage</a> 1@;y+p2h&CN
<a href="xxx.php?page=<?=ceil($num/10)-1?>">LastPage</a>
[/color][color=#000000][font=宋体][size=10.5pt]这是一个大致的思路,大家可以想想怎么来优化?十天学会[/size][/font]php[font=宋体][size=10.5pt]之第八天就说到这里,第九天说一下一些注意的问题。[/size][/font][/color]
页:
[1]