捌玖网络工作室's Archiver

admin 发表于 2008-3-26 16:40

十天学会php之第八天

[b][color=#ff6600] [/color][/b]
o_~ AO8{?9z [font=宋体][size=10.5pt][color=#000000]学习目的:做一个分页显示[/color][/size][/font]
+G Bc,mo ^ [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
.[FDQ{gosjc(b2^ Y5J*{*Op
[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`{8@c#}4|){/cN0y
2R:{)^9r xCb(|
[color=#000000]$execc="select count(*) from tablename ";7f9Rf,z I"[k H#d H+[ I
$resultc=mysql_query($execc);7L r ^#_%z:a
$rsc=mysql_fetch_array($resultc);
m&K@ZO9GWC%p^ $num=$rsc[0];
G+R,_6NDy%J0Q5k%IN g"Z7HmF5|vK1w
[/color][font=宋体][size=10.5pt][color=#000000]这样可以得到记录总数[/color][/size][/font] Ya"c"@5M#WKgI-a
[color=#000000]ceil($num/10))[/color][color=#000000][font=宋体][size=10.5pt]如果一页[/size][/font]10[font=宋体][size=10.5pt]记录的话,这个就是总的页数[/size][/font][/color]8~!X!LO6Vo
[font=宋体][size=10.5pt][color=#000000]所以可以这么写[/color][/size][/font]$]L3q&y&c"kP-FN
[color=#000000]if(empty($_GET['page']))
5p `,j'bN9dA{ {
s` Bk)f $page=0;
m-v|ex} }BWc5|2l8^\ q%v
else`A2Mp h4F
{8\t?p[1MC3d
$page=$_GET['page'];
;B)t2Nv8JO0Uc if($page<0)$page=0;
)A"M&@"A0rO/Z.sM 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
3GTo}XqYJ }
6e$J6_g(x\NBch2o6Z j qM8KVh"b*H6p)m
[font=宋体][size=10.5pt]这样[/size][/font]$exec[font=宋体][size=10.5pt]可以这么写[/size][/font][/color][color=#000000] $exec="select * from tablename limit ".($page*10).",10";
-l3U}d5R1n6ME //[font=宋体][size=10.5pt]一页是[/size][/font]10[font=宋体][size=10.5pt]记录的[/size][/font][/color]
9a vu#[ MpB%b%K [font=宋体][size=10.5pt][color=#000000]最后我们需要做的就是几个连接:[/color][/size][/font] fQGlU&Q
[color=#000000]<a href="xxx.php?page=0">FirstPage</a>
a {"{p:S3k <a href="xxx.php?page=<?=($page-1)?>">PrevPage</a>
]B T`)Xi*N <a href="xxx.php?page=<?=($page 1)?>">NextPage</a> Ku}6d\ \^
<a href="xxx.php?page=<?=ceil($num/10)-1?>">LastPage</a>
e)`"So.tH7p
Z(Re#{+B'}:c [/color][color=#000000][font=宋体][size=10.5pt]这是一个大致的思路,大家可以想想怎么来优化?十天学会[/size][/font]php[font=宋体][size=10.5pt]之第八天就说到这里,第九天说一下一些注意的问题。[/size][/font][/color]

页: [1]
【捌玖网络】已经运行:


Powered by Discuz! Archiver 7.2  © 2001-2009 Comsenz Inc.