【发布时间】:2013-01-07 22:59:29
【问题描述】:
我昨天问了一个类似的问题,但在等待之后,我发现了部分问题,但现在我又卡住了,当搜索结果太长时,我试图显示 ...,因为我的分页链接将继续显示并且在页面上显示每个链接之前不会停止。
例如,我试图在下面的示例中实现以下目标。有人可以帮我修复我的代码,以便我可以更新我的网站。谢谢
这就是我希望能够做到的。
First Previous 1 2 ... 5 6 7 8 9 10 11 12 13 ... 199 200 Next Last
这是显示链接的分页代码。
$display = 20;
if (isset($_GET['p']) && is_numeric($_GET['p'])) {
$pages = $_GET['p'];
} else {
$q = "SELECT COUNT(id) FROM comments WHERE user_id=3";
$r = mysqli_query ($mysqli, $q) or trigger_error("Query: $q\n<br />MySQL Error: " . mysqli_error($mysqli));
$row = mysqli_fetch_array ($r, MYSQLI_NUM);
$records = $row[0];
if ($records > $display) {
$pages = ceil ($records/$display);
} else {
$pages = 1;
}
}
if (isset($_GET['s']) && is_numeric($_GET['s'])) {
$start = $_GET['s'];
} else {
$start = 0;
}
//content goes here
if ($pages > 1) {
echo '<br /><p>';
$current_page = ($start/$display) + 1;
if ($current_page != 1) {
echo '<a href="index.php">First</a>';
}
if ($current_page != 1) {
echo '<a href="index.php?s=' . ($start - $display) . '&p=' . $pages . '">Previous</a> ';
}
for ($i = 1; $i <= $pages; $i++) {
if ($i != $current_page) {
echo '<a href="index.php?s=' . (($display * ($i - 1))) . '&p=' . $pages . '">' . $i . '</a> ';
} else {
echo '<span>' . $i . '</span> ';
}
}
if ($current_page != $pages) {
echo '<a href="index.php?s=' . ($start + $display) . '&p=' . $pages . '">Next</a>';
}
if ($current_page != $pages) {
echo '<a href="index.php?s=' . ($pages - 1) . '&p=' . $pages . '">Last</a>';
}
echo '</p>';
}
【问题讨论】:
-
哇,你很有耐心:“我昨天问了一个类似的问题,但在等了很久之后,我发现了问题的一部分......”我猜所有这些人都是你花钱来帮助的需要下车并做出回应。鼓励免费援助的方式。
-
你的其他问题怎么了?我在您的问题历史中没有看到它...
-
@MJB 我只是在寻求帮助并陈述事实,所有帮助总是值得赞赏的,但任何人的聪明评论都不是:)
-
@Mark Byers,这里是stackoverflow.com/questions/2807135/…
-
@TaG:当你的问题只是昨天的时候,我觉得说你永远等待是一个聪明的评论。所以我认为你根本不是在陈述事实——恰恰相反。
标签: php mysql pagination