请问“第 1 2 3 ...页”这种分页显示怎么做? 递交一个参数啊。你看比如第二页以后的链接的url,都是有个参数=那页的数值的。然后php或者asp得到这个递交的数以后,就判断是不是>或者=n,如果是小于的,就把前前后后的数字写出来就是了。很简单嘛。(如果光想不写的话:) 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 <?php/* function:break page author: date:2003.7.15 parameter: num=all of your pages; perpage= how many do you want to show; curr_page=current page; mpurl=current url; return: multipage=a string under your page*/function multi($num, $perpage, $curr_page, $mpurl) { if($num > $perpage) { $page = 10; $offset = 2; $pages = ceil($num / $perpage);//得到页数 $from = $curr_page - $offset;//偏移两页 $to = $curr_page + $page - $offset - 1; if($page > $pages) { $from = 1; $to = $pages; } else { if($from < 1) { $to = $curr_page + 1 - $from; $from = 1; if(($to - $from) < $page && ($to - $from) < $pages) { $to = $page; } } elseif($to > $pages) { $from = $curr_page - $pages + $to; $to = $pages; if(($to - $from) < $page && ($to - $from) < $pages) { $from = $pages - $page + 1; } } } $fwd_back .= "<a href=\"$mpurl&page=1\"><<</a> "; for($i = $from; $i <= $to; $i++) { if($i != $curr_page) { $fwd_back .= "<a href=\"$mpurl&&page=$i\">[$i]</a> "; } else { $fwd_back .= "<u><b>[$i]</b></u> "; } } $fwd_back .= $pages > $page ? " ... <a href=\"$mpurl&&page=$pages\"> [$pages] >></a>" : " <a href=\"$mpurl&&page=$pages\">>></a>"; $multipage = $fwd_back; } return $multipage; }//use//分页开始/*如果你有一个表叫XXXX,里面有字段叫cid和time,那么可以这样使用。第一次查询出总数num,第二次是进行你所要进行的真正查询,如内容什么的,mpurl是你当前页面的url,multipage是最后得到的一个分页串,*/$table="XXXX";$sql1 = "SELECT COUNT(*) AS rcnt FROM $table where cid=$cid ORDER BY time DESC";$result1 = @mysql_query($sql1);$array1 = @mysql_fetch_array($result1);$num = $array1[rcnt];$mpurl = "XXXX.php?cid=$cid";if(!empty($page)) { $start_limit = ($page - 1) * $morenum;}else { $start_limit = 0; $page = 1;}$multipage = multi($num,$morenum,$page,$mpurl);$sql="select * from $table where cid=$cid order by time desc limit $start_limit,$morenum";//分页结束$result = @mysql_query($sql);while($array = @mysql_fetch_array($result)){ XXXXX; }//至此已取得数组,不用我再写了吧,我得回家了。?> 在youngfly0137(杨)的激励下,我花了半个晚上动手写,终于自己想出了一个解决的方案,不知有没有纰漏,我是这样想的:假设$per_page是每页显示信息的条数,$long是一次显示的页数,比如显示“第 1 2 3 ...页”的话,$long就等于3了,$max_page是总页数,$topage是要去的那一页,也可以说是当前页当$max_page<2*$long时,直接显示所有页数。当$max_page>=2*$long时,又分为三种情况:$topage<$long+1时,就显示成诸如这样的:“第 1 2 3 ...页”当$long<$topage<$max_page-$long+1时,就显示成诸如这样的:“第 ...4 5 6 ...页”当$topage>$max_page-$long时,就显示成诸如这样的:“第 ...7 8 9 页”,下面是具体的代码:<?php$per_page=3;$long=3;if($topage<1)$topage=1;if($topage>$max_page)$topage=$max_page;echo "$topage/$max_page "; if($max_page>2*$long-1){ if($topage<$long+1){ echo"第"; for($i=1;$i<$long+1;$i++){ echo" <a href='show.php?topage=$i'>$i</a> "; } $temp=$long+1; echo"<a href='show.php?topage=$temp'>...</a> "; echo"页"; } if($topage>$max_page-$long) { echo"第"; $temp=$max_page-$long; echo" <a href='show.php?topage=$temp'>...</a>"; for($i=$max_page-$long+1;$i<$max_page+1;$i++){ echo" <a href='show.php?topage=$i'>$i</a> "; } echo"页"; } if($topage>$long&&$topage<$max_page-$long+1){ echo"第"; $temp=$topage-1; echo" <a href='show.php?topage=$temp'>...</a>"; for($i=$topage;$i<$long+$topage;$i++){ echo" <a href='show.php?topage=$i'>$i</a> "; } $temp=$long+$topage; echo"<a href='show.php?topage=$temp'>...</a> "; echo"页"; }}else{ echo"第"; for($i=1;$i<$max_page+1;$i++){ echo" <a href='show.php?topage=$i'>$i</a> "; } echo"页";}?>至于怎样读数据库得到$max_page,和数据的移动,我就不多说了。我用了几组$per_page和$long的值去验证,发觉都是正确的!至于有没有其他逻辑的漏洞就不知道了,如果有的话,请大家指出! 还有不管怎样要感谢ustb(偶然),虽然我还没看他贴的那段代码(PS:我今晚看完这么长的代码肯定会睡不着的)。 还是自己写的好。真的这样才能学到东西。不过人家ustb(偶然)为你晚回家,看到你这段话要气死的^^ 诚挚请教PHP前辈们一些问题! 字符串连接,为何说我错了? 怎么产生多个session_id? 如果遇到这个问题??该怎么办???(有挑战性的问题) 给一个数据输入的思路 估计这不是个大问题,请看看! 快被php弄疯了,原来好好的,重新装到xp系统上session就不能注册变量了???? 读取word出现乱码????? 求帮助,PHP脚本 新手求问一个,页面之间的传值问题 如何判定一个值是否在另一个数组内?(在线等,急) 有见过这种情况没有
/*
function:break page
author:
date:2003.7.15
parameter: num=all of your pages;
perpage= how many do you want to show;
curr_page=current page;
mpurl=current url; return:
multipage=a string under your page
*/
function multi($num, $perpage, $curr_page, $mpurl)
{
if($num > $perpage)
{
$page = 10;
$offset = 2; $pages = ceil($num / $perpage);//得到页数
$from = $curr_page - $offset;//偏移两页
$to = $curr_page + $page - $offset - 1;
if($page > $pages)
{
$from = 1;
$to = $pages;
}
else
{
if($from < 1)
{
$to = $curr_page + 1 - $from;
$from = 1;
if(($to - $from) < $page && ($to - $from) < $pages)
{
$to = $page;
}
}
elseif($to > $pages)
{
$from = $curr_page - $pages + $to;
$to = $pages;
if(($to - $from) < $page && ($to - $from) < $pages)
{
$from = $pages - $page + 1;
}
}
}
$fwd_back .= "<a href=\"$mpurl&page=1\"><<</a> ";
for($i = $from; $i <= $to; $i++)
{
if($i != $curr_page)
{
$fwd_back .= "<a href=\"$mpurl&&page=$i\">[$i]</a> ";
}
else
{
$fwd_back .= "<u><b>[$i]</b></u> ";
}
}
$fwd_back .= $pages > $page ? " ... <a href=\"$mpurl&&page=$pages\"> [$pages] >></a>" : " <a href=\"$mpurl&&page=$pages\">>></a>";
$multipage = $fwd_back;
}
return $multipage;
}//use//分页开始/*
如果你有一个表叫XXXX,里面有字段叫cid和time,那么可以这样使用。第一次查询出总数num,第二次是进行你所要进行的真正查询,如内容什么的,
mpurl是你当前页面的url,multipage是最后得到的一个分页串,
*/
$table="XXXX";
$sql1 = "SELECT COUNT(*) AS rcnt FROM $table where cid=$cid ORDER BY time DESC";
$result1 = @mysql_query($sql1);
$array1 = @mysql_fetch_array($result1);
$num = $array1[rcnt];
$mpurl = "XXXX.php?cid=$cid";
if(!empty($page)) {
$start_limit = ($page - 1) * $morenum;
}
else {
$start_limit = 0;
$page = 1;
}
$multipage = multi($num,$morenum,$page,$mpurl);
$sql="select * from $table where cid=$cid order by time desc limit $start_limit,$morenum";
//分页结束
$result = @mysql_query($sql);
while($array = @mysql_fetch_array($result)){
XXXXX;
}//至此已取得数组,不用我再写了吧,我得回家了。?>
假设$per_page是每页显示信息的条数,$long是一次显示的页数,比如显示“第 1 2 3 ...页”的话,$long就等于3了,$max_page是总页数,$topage是要去的那一页,也可以说是当前页
当$max_page<2*$long时,直接显示所有页数。当$max_page>=2*$long时,又分为三种情况:
$topage<$long+1时,就显示成诸如这样的:“第 1 2 3 ...页”
当$long<$topage<$max_page-$long+1时,就显示成诸如这样的:“第 ...4 5 6 ...页”
当$topage>$max_page-$long时,就显示成诸如这样的:“第 ...7 8 9 页”,下面是具体的代码:
<?php
$per_page=3;
$long=3;
if($topage<1)$topage=1;
if($topage>$max_page)$topage=$max_page;
echo "$topage/$max_page ";
if($max_page>2*$long-1){
if($topage<$long+1){
echo"第";
for($i=1;$i<$long+1;$i++){
echo" <a href='show.php?topage=$i'>$i</a> ";
}
$temp=$long+1;
echo"<a href='show.php?topage=$temp'>...</a> ";
echo"页";
}
if($topage>$max_page-$long)
{
echo"第";
$temp=$max_page-$long;
echo" <a href='show.php?topage=$temp'>...</a>";
for($i=$max_page-$long+1;$i<$max_page+1;$i++){
echo" <a href='show.php?topage=$i'>$i</a> ";
}
echo"页";
}
if($topage>$long&&$topage<$max_page-$long+1){
echo"第";
$temp=$topage-1;
echo" <a href='show.php?topage=$temp'>...</a>";
for($i=$topage;$i<$long+$topage;$i++){
echo" <a href='show.php?topage=$i'>$i</a> ";
}
$temp=$long+$topage;
echo"<a href='show.php?topage=$temp'>...</a> ";
echo"页";
}
}
else
{
echo"第";
for($i=1;$i<$max_page+1;$i++){
echo" <a href='show.php?topage=$i'>$i</a> ";
}
echo"页";
}
?>
至于怎样读数据库得到$max_page,和数据的移动,我就不多说了。我用了几组$per_page和$long的值去验证,发觉都是正确的!至于有没有其他逻辑的漏洞就不知道了,如果有的话,请大家指出!
不过人家ustb(偶然)为你晚回家,看到你这段话要气死的^^