Признаюсь честно код взял в интернете, он работает, но проблема в том что он берет все записи c бд и делит на лимит выводимых записей на странице, то есть если на главной выбирает все записи (в моем случае 20 штук), то получается 20 страниц (если лимит равен 1), а на категориях там где идет выборка он все равно берет общее число записей, а не количество которых мне надо, вот можете посмотреть http://zena[dot]hol[dot]es , и получается что в категориях 20 страниц, а записей меньше,а то и вовсе нету. Как сделать что бы количество страниц соответствовало количеству ВЫВОДИМЫХ записей
CODE ( htmlphp):
скопировать код в буфер обмена
$tableName="films"; $targetpage = "index.php?id=ganre&ganre=$ganre"; $limit = 4; $query = "SELECT COUNT(*) as num FROM $tableName"; $total_pages = mysqli_fetch_array(mysqli_query($bd, $query)); $total_pages = $total_pages[num]; $stages = 3; $page = mysqli_escape_string($bd, $_GET['page']); if($page){ $start = ($page - 1) * $limit; }else{ $start = 0; } // Get page data $query1 = "SELECT * FROM $tableName WHERE ganre LIKE '%$ganre%' order by id desc LIMIT $start, $limit"; $result = mysqli_query($bd, $query1); // Initial page num setup if ($page == 0){$page = 1;} $prev = $page - 1; $next = $page + 1; $lastpage = ceil($total_pages/$limit); $LastPagem1 = $lastpage - 1; $paginate = ''; if($lastpage > 1) { $paginate .= "<div class='paginate'>"; // Previous if ($page > 1){ $paginate.= "<a href='$targetpage&page=$prev'>Предыдущая</a>"; }else{ $paginate.= "<span class='disabled'>Предыдущая</span>"; } // Pages if ($lastpage < 7 + ($stages * 2)) // Not enough pages to breaking it up { for ($counter = 1; $counter <= $lastpage; $counter++) { if ($counter == $page){ $paginate.= "<span class='current'>$counter</span>"; }else{ $paginate.= "<a href='$targetpage&page=$counter'>$counter</a>";} } } elseif($lastpage > 5 + ($stages * 2)) // Enough pages to hide a few? { // Beginning only hide later pages if($page < 1 + ($stages * 2)) { for ($counter = 1; $counter < 4 + ($stages * 2); $counter++) { if ($counter == $page){ $paginate.= "<span class='current'>$counter</span>"; }else{ $paginate.= "<a href='$targetpage&page=$counter'>$counter</a>";} } $paginate.= "..."; $paginate.= "<a href='$targetpage&page=$LastPagem1'>$LastPagem1</a>"; $paginate.= "<a href='$targetpage&page=$lastpage'>$lastpage</a>"; } // Middle hide some front and some back elseif($lastpage - ($stages * 2) > $page && $page > ($stages * 2)) { $paginate.= "<a href='$targetpage&page=1'>1</a>"; $paginate.= "<a href='$targetpage&page=2'>2</a>"; $paginate.= "..."; for ($counter = $page - $stages; $counter <= $page + $stages; $counter++) { if ($counter == $page){ $paginate.= "<span class='current'>$counter</span>"; }else{ $paginate.= "<a href='$targetpage&page=$counter'>$counter</a>";} } $paginate.= "..."; $paginate.= "<a href='$targetpage&page=$LastPagem1'>$LastPagem1</a>"; $paginate.= "<a href='$targetpage&page=$lastpage'>$lastpage</a>"; } // End only hide early pages else { $paginate.= "<a href='$targetpage&page=1'>1</a>"; $paginate.= "<a href='$targetpage&page=2'>2</a>"; $paginate.= "..."; for ($counter = $lastpage - (2 + ($stages * 2)); $counter <= $lastpage; $counter++) { if ($counter == $page){ $paginate.= "<span class='current'>$counter</span>"; }else{ $paginate.= "<a href='$targetpage&page=$counter'>$counter</a>";} } } } // Next if ($page < $counter - 1){ $paginate.= "<a href='$targetpage&page=$next'>Следующая</a>"; }else{ $paginate.= "<span class='disabled'>next</span>"; } $paginate.= "</div>"; }
(Отредактировано автором: 24 Ноября, 2015 - 23:57:36)
|