getData($s">
当前位置:Gxlcms > PHP教程 > php文章列表分页代码如何写

php文章列表分页代码如何写

时间:2021-07-01 10:21:17 帮助过:19人阅读

php文章列表分页代码怎么写?
$sql = "SELECT * FROM `links` WHERE `subdomain` != '' ORDER BY id desc LIMIT 100";
$rows = $db->getData($sql);
foreach($rows as $row)
{
echo '
  • '.$row['title'].'
  • ';
    }

    第一页的文章调用我会写,但是要分页不知道怎么写
    现在有字段 title subdomain
    ------解决思路----------------------
    直接找个分页函数应用就可以了。
    大约参数如下:
    1 总数
    2 当前页
    3 每页数量
    4 baseUrl,你所说的title及subdomain都以GET方式传送。
    5 显示页面数量

    class CCustomWidgets {
    public static function Pager($totalPages, $pageNumber, $pageSize, $url, $displayNumber = 6) {
    $baseUrl = (strpos($url, "?") === false) ? $url.'?page=' : $url.'&page=';
    $pager = '
      ';

      $prevPage = $pageNumber - 1;
      if($prevPage > 0){
      $pager .= '
    • ??????é??
    • ';
      }

      if($totalPages - $pageNumber < $displayNumber) {
      $displayStart = ($totalPages >= $displayNumber) ? ($totalPages - $displayNumber + 1) : 1;
      $displayEnd = $totalPages;
      }else{
      if($pageNumber % $displayNumber){
      $displayStart = floor($pageNumber / $displayNumber) * $displayNumber + 1;
      $displayEnd = (floor($pageNumber / $displayNumber) + 1) * $displayNumber;
      }else{
      $displayStart = (floor(($pageNumber / $displayNumber) - 1)) * $displayNumber + 1;
      $displayEnd = (floor($pageNumber / $displayNumber)) * $displayNumber;
      }
      }


      for(; $displayStart <= $displayEnd; $displayStart++) {
      $pager .= '
    • '.$displayStart.'
    • ';
      }
      if($pageNumber < $totalPages){
      $pager .= '
    • ??????é??
    • ';
      }
      $pager .= "
    ";
    return $pager;
    }
    }



    ------解决思路----------------------
    如果你的分页要在数据库上做的话 这两个字段不够啊,你只有标题和文章的一部分。 你至少还要标识出这个domain是文章的第几段/页 还有就是标识文章的id 标题是能够重复的

    人气教程排行