如何限制分页系统PHP / MySQL中的页面?

时间:2015-02-01 05:19:17

标签: php mysql pagination

我的用户仪表板有一个分页系统,基本上我担心的是当用户的朋友开始发布到50-60-70页的点时。

我希望如此:1 2 3 4 5 ... 91 然后当用户加载不同的页面时,请按以下方式进行:1 ... 22 23 24 ... 91

或者那种事情。这样它就不会尝试一次列出所有页面而变得非常难看。

我不是很喜欢分页,而且我有一位老朋友帮助我使用这个系统,很抱歉,如果这是一个无聊的问题。我在网上看了一下东西,似乎无法找到一种方法来实现我正在尝试用我的系统做的事情。

我应该重拍整件事吗?如果是这样,那么最好的方法是什么?这是我正在使用的当前功能:

function friendstatus(){
    global $session_user_id;
    $per_page = 15;
    $from_where = "FROM posts WHERE userid in (SELECT friend_id FROM friendship WHERE user_id = $session_user_id AND pending = 0 OR friend_id = $session_user_id) AND visible != 0 ORDER BY `timestamp` DESC";
    $sql = "SELECT COUNT(*) ".$from_where;
    $res = mysql_query($sql) or trigger_error("Error.");
    $row = mysql_fetch_row($res);
    $total_rows = $row[0];
    if($total_rows != 0){
        if(isset($_GET['page'])) $CUR_PAGE = intval($_GET['page']); else $CUR_PAGE=1;
        $start = abs(($CUR_PAGE-1)*$per_page);
        $sql = "SELECT * $from_where LIMIT $start,$per_page";
        $res = mysql_query($sql) or trigger_error("cant get actual data");
        while($row=mysql_fetch_array($res)) $DATA[++$start]=$row;
        $uri = strtok("/dash","?")."/";
        $tmpget = $_GET;
        unset($tmpget['page']);
        if($tmpget){ $uri .= http_build_query($tmpget)."/"; }
        $num_pages=ceil($total_rows/$per_page);
        for($i=1;$i<=$num_pages;$i++) $PAGES[$i]=$uri.$i; ?>

        Pages:<? foreach ($PAGES as $i => $link): ?> <? if ($i == $CUR_PAGE): ?><b><?=$i?></b> <? else: ?><a href="<?=$link?>"><?=$i?></a> <? endif ?><? endforeach ?> | Total Posts: <b><?=$total_rows?></b>
        <hr color="#1F1F1F" width="100%"><br><?foreach($DATA as $i => $row):?>

        //show the statuses

        <? endforeach ?>

        Pages:<? foreach ($PAGES as $i => $link): ?> <? if ($i == $CUR_PAGE): ?><b><?=$i?></b> <? else: ?><a href="<?=$link?>"><?=$i?></a> <? endif ?><? endforeach ?> | Total Posts: <b><?=$total_rows?></b>
    <? } //end if $total_rows != 0 
} //end function 

2 个答案:

答案 0 :(得分:0)

首先在您想要显示的当前页面周围定义一些范围。

$RANGE = 2; //show 2 pages before and after current

然后确定此范围的开始和结束页面:

$start = max($CUR_PAGE-$RANGE,1);
$end = min($CUR_PAGE+$RANGE,count($PAGES));

然后替换你的

foreach($PAGES as $i=>$link)

for($i=$start;$i<=$end;$i++) //references to $link in the body become $PAGES[$i] 

对于静态“前x页”和“最后x页”,你必须做一些检查,以确保你不会得到重复的页面,如1 ... 12345 ... 91。如果您只想拥有指向第一页和最后一页的链接,那么简单的if语句就足够了,例如,如果要显示第一页和后三页,则必须进行一些小的索引调整。 / p>

答案 1 :(得分:0)

通过抛出一些if语句,我基本上能够实现我想要的目标。

用......替换列出页面的部分

<a href="https://mysite/dash/1">First</a> | <? foreach ($PAGES as $i => $link): ?><? if ($i == $CUR_PAGE): ?><b><?=$i?></b> <? endif ?><? if($i == $CUR_PAGE+1):?><a href="<?=$link?>"><?=$i?></a><? endif ?><? endforeach ?> | <a href="https://mysite/dash/<?=$num_pages?>">Last</a> | Total Posts: <b><?=$total_rows?></b>