Постраничная навигация на PHP
Разрабатывая очередной проект, будь то крупный сайт или маленький скрипт, бывает необходимость в использовании постраничной разбивки выводимых данных. И реализация кнопок постраничной навигации. Казалось бы чего проще? Но не смотря на достаточно простую задачу, у многих программистов порой уходит час, а то и более на написание скрипта постраничной навигации. В то время, когда можно использовать готовое решение, и не тратить драгоценное денежное время на простые банальности.
Добавлено: новая версия скрипта постраничной навигации
Предлагаю вашему вниманию решение, которое я использую в своих проектах. На мой взгляд этот код достаточно универсален и его легко встроить в любой скрипт или CMS.
Скрипт на PHP
<?php //Настройки подключения к БД $db_host = 'localhost'; $db_name = 'dbname'; $db_user = 'user'; $db_pass = 'pass'; $page = intval($_GET[page]); // значение текущей страницы из GET $num = 10; // Переменная хранит число сообщений выводимых на станице if ($page==0) $page=1; // Определяем общее число сообщений в базе данных // Берем из БД кол-во записей mysql_connect($db_host,$db_user,$db_pass) OR DIE("Error connect to SQL<br/> "); // коннект к БД, указать хост, лог и пасс @mysql_select_db("$db_name") or die("Error connect to DB<br/>"); mysql_query ("set character_set_client='utf8'"); // установка кодировки ( возможно у вас cp1251) mysql_query ("set character_set_results='utf8'"); mysql_query ("set collation_connection='utf8_general_ci'"); $query = "SELECT count(`id`) FROM `table`"; // строка запроса в БД, "table" - заменить на название вашей таблицы $mysql_result = mysql_query($query); if(mysql_num_rows($mysql_result)>0){ $count=mysql_fetch_row($mysql_result); } $posts = $count[0]; // получем значение кол-во всех записей // Находим общее число страниц $total = intval(($posts - 1) / $num) + 1; // Определяем начало сообщений для текущей страницы $page = intval($page); // Если значение $page меньше единицы или отрицательно // переходим на первую страницу // А если слишком большое, то переходим на последнюю if(empty($page) or $page < 0) $page = 1; if($page > $total) $page = $total; // Вычисляем начиная к какого номера // следует выводить сообщения $start = $page * $num - $num; // Проверяем нужны ли стрелки назад if ($page != 1) $pervpage = '<a href="/index.php?page=-1"><<</a> <a href="/index.php?page='. ($page - 1).'"><</a> '; // Проверяем нужны ли стрелки вперед if ($page != $total) $nextpage = ' <a href="/index.php?page='. ($page + 1).'">></a> <a href="/index.php?page='.$total.'">>></a> '; // Находим две ближайшие станицы с обоих краев, если они есть if($page - 2 > 0) $page2left = ' <a href="/index.php?page='. ($page - 2) .'">'. ($page - 2) .'</a> '; if($page - 1 > 0) $page1left = '<a href="/index.php?page='. ($page - 1) .'">'. ($page - 1) .'</a> '; if($page + 2 <= $total) $page2right = ' <a href="/index.php?page='. ($page + 2).'">'. ($page + 2) .'</a>'; if($page + 1 <= $total) $page1right = ' <a href="/index.php?page='. ($page + 1).'">'. ($page + 1) .'</a>'; //получаем записи из БД (начиная с $start, кол-во записей = $num) $query = "SELECT * FROM `table` LIMIT $start, $num"; $mysql_result = mysql_query($query); ?> |
Выводим ссылки на страницы:
<?php // если страниц больше чем одна if ($total>1) echo '<p><div align="center" class="navigation">' .$pervpage.$page2left.$page1left.'<span>'.$page.'</span>'.$page1right.$page2right .$nextpage.'</div></p>'; ?> |
Стили оформления кнопок навигации:
.navigation { color: #636363; border: 0px; font-family: tahoma; } .navigation a:link, .navigation a:visited, .navigation a:active { display: inside; text-decoration: none; color: #FFF; background-color: #13739B; border: 1px solid #e1e1e3; padding: 3px 6px; font-size: 11px } .navigation a:hover { background-color: #24323B; color: #ffffff; border-color: #e1e1e3; } .navigation span { text-decoration: none; background-color: #24323B; padding: 3px 6px; border: 1px solid #e1e1e3; color: #fff; font-size: 11px; } .navigation span.nav_ext { border: none; background: transparent; } |
Разумеется не что, не мешает переделать данный скрипт под свои конкретные цели и задачи, но как правило в большинстве случаев этого вполне хватает.
Если возникнут вопросы по установке или какому-то участку кода, пишите в комментариях, постараюсь максимально объяснить, что и куда.
Похожие записи
22 комментария to “Постраничная навигация на PHP”
Оставить комментарий
Full Stack
Senior, Architect
предложить оффер
- jQuery: как получить значение атрибута?
- PHP работа с изображением, класс SimpleImage
- Интеграция с API ОСАГО сайта sravni.ru
- Комментарии на PHP, Ajax, mySQL
- PHP: Категории бесконечного уровня вложенности.
- Nginx редирект на другой сервис с сохранением URL спросил (а) Сергей
- Исполнитель пропал, почему такое случается и понять с кем работать? спросил (а) Артем
- Можно ли WordPress считать универсальным движком? спросил (а) Андрей
- Что такое самописный скрипт или CMS? спросил (а) Антон
- Как при поиске в linux используя grep, добавить исключения? спросил (а) Алексей
- Консольный скрипт(JavaScript) для автоматических заказов на OZON к записи
- Консольный скрипт(JavaScript) для автоматических заказов на OZON к записи
- Как создать Telegram-бота с авторизацией через сайт к записи
- PHP скрипт: каталог закладок на сайты к записи
- Валидация на PHP к записи
- Сколько зарабатывают в бизнесе на совместных покупках к записи
- Сколько зарабатывают в бизнесе на совместных покупках к записи
Archive
- +2024 (31)
- Декабрь 2024 (3)
- Ноябрь 2024 (13)
- Октябрь 2024 (8)
- Сентябрь 2024 (1)
- Август 2024 (5)
- Май 2024 (1)
- +2023 (27)
- Ноябрь 2023 (1)
- Октябрь 2023 (13)
- Сентябрь 2023 (10)
- Апрель 2023 (1)
- Март 2023 (1)
- Февраль 2023 (1)
- +2022 (21)
- Декабрь 2022 (11)
- Ноябрь 2022 (1)
- Май 2022 (2)
- Апрель 2022 (2)
- Март 2022 (3)
- Февраль 2022 (1)
- Январь 2022 (1)
- +2021 (17)
- Декабрь 2021 (5)
- Ноябрь 2021 (2)
- Июль 2021 (1)
- Июнь 2021 (2)
- Май 2021 (5)
- Апрель 2021 (1)
- Март 2021 (1)
- +2020 (20)
- Декабрь 2020 (6)
- Сентябрь 2020 (2)
- Август 2020 (1)
- Июль 2020 (2)
- Май 2020 (2)
- Апрель 2020 (2)
- Март 2020 (2)
- Февраль 2020 (1)
- Январь 2020 (2)
- +2019 (18)
- Декабрь 2019 (3)
- Ноябрь 2019 (2)
- Октябрь 2019 (2)
- Сентябрь 2019 (1)
- Август 2019 (2)
- Июль 2019 (1)
- Июнь 2019 (1)
- Апрель 2019 (2)
- Март 2019 (1)
- Февраль 2019 (3)
- +2018 (44)
- Декабрь 2018 (4)
- Ноябрь 2018 (7)
- Октябрь 2018 (8)
- Сентябрь 2018 (1)
- Август 2018 (4)
- Июль 2018 (5)
- Май 2018 (3)
- Апрель 2018 (7)
- Март 2018 (1)
- Февраль 2018 (2)
- Январь 2018 (2)
- +2017 (19)
- Декабрь 2017 (2)
- Ноябрь 2017 (1)
- Октябрь 2017 (1)
- Сентябрь 2017 (2)
- Июль 2017 (1)
- Июнь 2017 (1)
- Май 2017 (2)
- Апрель 2017 (3)
- Март 2017 (2)
- Февраль 2017 (1)
- Январь 2017 (3)
- +2016 (36)
- Декабрь 2016 (3)
- Ноябрь 2016 (3)
- Октябрь 2016 (2)
- Сентябрь 2016 (3)
- Август 2016 (7)
- Июнь 2016 (3)
- Май 2016 (3)
- Апрель 2016 (3)
- Февраль 2016 (1)
- Январь 2016 (8)
- +2015 (36)
- Ноябрь 2015 (5)
- Октябрь 2015 (4)
- Сентябрь 2015 (1)
- Август 2015 (8)
- Июнь 2015 (1)
- Май 2015 (4)
- Апрель 2015 (8)
- Март 2015 (3)
- Февраль 2015 (2)
- +2014 (26)
- Ноябрь 2014 (2)
- Октябрь 2014 (5)
- Сентябрь 2014 (6)
- Июль 2014 (1)
- Июнь 2014 (2)
- Май 2014 (3)
- Апрель 2014 (6)
- Февраль 2014 (1)
- +2013 (27)
- Декабрь 2013 (2)
- Ноябрь 2013 (1)
- Октябрь 2013 (1)
- Август 2013 (1)
- Июль 2013 (3)
- Июнь 2013 (10)
- Май 2013 (1)
- Апрель 2013 (2)
- Февраль 2013 (3)
- Январь 2013 (3)
- +2012 (41)
- Декабрь 2012 (2)
- Ноябрь 2012 (3)
- Октябрь 2012 (7)
- Сентябрь 2012 (2)
- Август 2012 (1)
- Июль 2012 (3)
- Июнь 2012 (2)
- Май 2012 (6)
- Апрель 2012 (2)
- Март 2012 (7)
- Февраль 2012 (5)
- Январь 2012 (1)
- +2011 (57)
- Декабрь 2011 (6)
- Ноябрь 2011 (2)
- Октябрь 2011 (3)
- Сентябрь 2011 (5)
- Август 2011 (4)
- Июль 2011 (3)
- Июнь 2011 (3)
- Май 2011 (3)
- Апрель 2011 (4)
- Март 2011 (10)
- Февраль 2011 (5)
- Январь 2011 (9)
- +2010 (43)
- Декабрь 2010 (7)
- Ноябрь 2010 (21)
- Октябрь 2010 (14)
- Сентябрь 2010 (1)
Свежие записи
- Пакетное добавление сайтов в панель ISP Manager 6 07.12.2024
- Обрезка документа PDF в Linux из PHP 06.12.2024
- Прокси веб-сервера Apache и nGinx 03.12.2024
- Настройка WebSocket на сайте для быстрого обмена данными 30.11.2024
- Подключение сайта к доставке DPD по API 28.11.2024
Скажите, а как в этом скрипте реализовать примерно такое << < ..2|3|4|5|6.. > >>
Т.е., если страниц больше 5, то скрывать остальные и добавить точки ().
Для реализации вывода навигации с большим числом отображаемых страниц(ссылок), нужно немного дописать код. Я предлагаю просто в зависимости от кол-ва страниц добавлять n-ое кол-во ссылок, добавив соответствующее условие, и внутри него цикл. Честно говоря, тоже сталкивался с данной задачей, но пока руки не дошли, в ближайшее время допишу код и выложу здесь.
думаю реализация точек тоже не составит труда, предусмотрю этот момент когда буду переписывать код
Роман, я на днях начал делать сайт, и столкнулся с необходимостью постраничной навигации по сайту. Причём мне нужно вставлять даже не один скрипт, а, скорее всего, несколько. То есть, переходы на следующую страницу осуществляются нажатием на ссылку «ЧИТАТЬ ЕЩЁ…» (это в текстовом разделе), а в разделе изображений «СМОТРЕТЬ ЕЩЁ…». Но так как, страниц становится больше, то и возникла такая необходимость, как постраничная навигация.
Всё, что я нашёл (на данный момент) в Сети — это ничего с маслом. ваш скрипт меня заинтересовал, всё, вроде, понятно. Непонятно, как (и куда?) его устанавливать? Его же, наверное, нужно в корневой каталог помещать?
Буду очень благодарен, если ответите на почту — так будет удобнеее.
Спасибо.
Обновил код, он содержал лишние строки.
Данный кусок года следует вставить в скрипт отвечающий за вывод списка записей в категории. Какая у вас CMS ? Могу помочь с установкой кода в скрипт.
Почему в переменной total всегда 1 ?
Возможно при запросе в базу, чтобы узнать общее кол-во всех записей, возвращается значение ноль, в результате $total всегда равен 1
if(mysql_num_rows($mysql_result)>0)
{
$count=mysql_fetch_row($mysql_result);
}
$posts = $count[0];
Вот так считает…
Ну и чтоб добить и работало как надо, укажите класс для див в выводе ссылок 🙂
Какую формулу выставлять чтобы отображалось только две записи на страницы?
Поменять значение
$num = 10;
на
$num = 2;
к этомой строке
$total = intval(($posts — 1) / $num) + 1;
выдается вот такая ошибка
Warning: Division by zero in Q:\home\reklama\www\nov\str.php on line 42
причем на всех скриптах где идет расчет колличества страниц этой формой
Данная ошибка означает, что вы пытаеттесь делить на ноль, чего делать нельзя. Очевидно, что переменная $num содержит ноль. Исправьте это.
Скрипт копирую один в один только подключение свое и меняю таблицу базы данных
<?php
$result77 = mysql_query("SELECT str FROM options", $db);
$myrow77 = mysql_fetch_array($result77);
$num = $myrow77["str"];
@$page = $_GET['page'];
$result00 = mysql_query("SELECT COUNT(*) FROM nov_pr WHERE id='$id'");
$temp = mysql_fetch_array($result00);
$posts = $temp["0"];
$total =intval(($posts — 1) / $num) + 1;
$total =intval($total);
$page = intval($page);
if(empty($page) or $page $total) $page = $total;
$start = $page * $num — $num;
$result = mysql_query(«SELECT *FROM nov_pr WHERE id=’$id’ ORDER BY id LIMIT $start, $num»,$db);
?>
вотон скрипт идентичный вашему только значение «num» берется из таблици «options» и все равно на строку
$total =intval(($posts — 1) / $num) + 1;
аналогичная ошибка
Warning: Division by zero in Q:\home\reklama\www\nov\str.php on line 45
Ребята если можно помогите пожалуйста, вообще не понимаю что за ерунда, у всер работает а у меня как обычно
Про ошибку отписал выше, а вот этот кусок кода(запрос в БД) совершенно не верен
SELECT COUNT(*) FROM nov_pr WHERE id=’$id'»
Ведь запись с указанном ID всего одна?
замените, на
SELECT COUNT(*) FROM nov_pr
Спасибо за статью!
Но у меня возникла необходимость сделать постраничную навигацию к плагину WordPress
Плагин – каталог ссылок. Этот каталог вставляется на страницу через шорт код: add_shortcode(‘code’, ‘shortcod’);
То есть каталог вставляется на определенную страницу сайта. И когда добавляю постраничную навигацию, при переходе на страницу «2», ВордПресс выдает «404 страница не найдена:(».
Каким способом можно решить эту проблему?
Третий день сижу, мозг кипит!)
Буду благодарен, если подскажете начинающему, но очень перспективному программисту…:)
Вам нужно разобраться с самим кодом отвечающим за вывод каталога, возможно модифицировав плагин получится сделать постраничную навигацию.
А данный скрипт подойдет для фото галереи? Точнее есть просто страница с фотками, которые при помощи JQuery, открываются в увеличенном размере. Просто хотел разбить на страницы «фото галерею». Но возникает вопрос как работать с данным скриптом, куда его вставлять????
Сложно сказать однозначно, т.к. прежде требуется понять структуру вашего скрипта, но думаю что подойдет.
Подскажите пожалуйста , у меня сайт на html , можно ли как — нибудь внедрить туда этот код , чтоб с бд подгружалось ??
Теоретически можно, если ваш хостинг поддерживает PHP и есть mySQL, а также все записи хранятся в БД, т.е. есть некая структура. Но боюсь если сам сайт на html, то БД он не использует и для навигации с помощью данного скрипта придется перекраивать сам сайт и делать еще много какой работы.