递交一个参数啊。你看比如第二页以后的链接的url,都是有个参数=那页的数值的。然后php或者asp得到这个递交的数以后,就判断是不是>或者=n,如果是小于的,就把前前后后的数字写出来就是了。
很简单嘛。(如果光想不写的话:)

解决方案 »

  1.   

    <?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\">&lt;&lt;</a> &nbsp;";
    for($i = $from; $i <= $to; $i++)
    {
    if($i != $curr_page)
    {
    $fwd_back .= "<a href=\"$mpurl&&page=$i\">[$i]</a>&nbsp;";
    }
    else
    {
    $fwd_back .= "<u><b>[$i]</b></u>&nbsp;";
    }
    }
    $fwd_back .= $pages > $page ? " ... <a href=\"$mpurl&&page=$pages\"> [$pages] &gt;&gt;</a>" : " <a href=\"$mpurl&&page=$pages\">&gt;&gt;</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;
    }//至此已取得数组,不用我再写了吧,我得回家了。?>
      

  2.   

    在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的值去验证,发觉都是正确的!至于有没有其他逻辑的漏洞就不知道了,如果有的话,请大家指出!
      

  3.   

    还有不管怎样要感谢ustb(偶然),虽然我还没看他贴的那段代码(PS:我今晚看完这么长的代码肯定会睡不着的)。
      

  4.   

    还是自己写的好。真的这样才能学到东西。
    不过人家ustb(偶然)为你晚回家,看到你这段话要气死的^^