我的用户仪表板有一个分页系统,基本上我担心的是当用户的朋友开始发布到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
答案 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>