Слава Україні!

Постраничная навигация на php

Простая реализация перехода по страницам с помощью php
7-го квітня 2012, 3:04
Проблема реализации постраничной навигации часто встает перед начинающими PHP-программистами. К разбиению объёмного текста на отдельные страницы прибегают во многих Web-приложениях от гостевых книг и форумов до различных каталогов. Давайте решим эту проблему. Итак, что нам требуется для реализации постраничной навигации? Для примера возьмем гостевую книгу, содержащую несколько сотен сообщений, в которой требуется выводить на страницу Х сообщений. Рассмотрим задачу более конкретно. Сообщения пользователей хранятся в базе данных, в таблице `post` со следующей структурой: - id – номер сообщения, - text – тело сообщения, - name – имя автора, - time – время создания. В итоге нам надо получить вывод Х сообщений на страницу, а также организовать удобную навигацию, например, такую: `<< < ..2|3|4|5|6.. > >>` где 4 - текущая станица. Для того чтобы отслеживать текущую страницу, будем использовать параметр `page`, передаваемый через URL. К примеру: `www.myserver.com/index.php?page=X`. Здесь X - номер станицы (для примера, пусть Х будет равно 25). Теперь, после этого небольшого введения, можно приступать к непосредственной реализации.

    // Устанавливаем соединение с базой данных
    include "config.php";
    // Переменная хранит число сообщений выводимых на станице
    $num = 25;
    // Извлекаем из URL текущую страницу
    $page = $_GET['page'];
    // Определяем общее число сообщений в базе данных
    $result = mysql_query("SELECT COUNT(*) FROM post");
    $posts = mysql_result($result, 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;
    // Выбираем $num сообщений начиная с номера $start
    $result = mysql_query("SELECT * FROM post LIMIT $start, $num");
    // В цикле переносим результаты запроса в массив $postrow
    while ( $postrow[] = mysql_fetch_array($result))
На этом первая часть закончена. Двумерный массив `postrow` хранит все поля таблицы `post`, необходимые для отображения станицы. Вот пример как можно организовать вывод сообщений. echo ""; for($i = 0; $i < $num; $i++) { echo ""; } echo "
".$postrow[$i]['name']." ".$postrow[$i]['time']."
".$postrow[$i]['text']."
"; Теперь надо организовать навигацию. Формируем составляющие будущей навигации. Коды стрелки «в начало» и «назад» поместим в одну переменную, также поступим и со стрелками «в конец» и «вперед». // Проверяем нужны ли стрелки назад if ($page != 1) $pervpage = '<< < '; // Проверяем нужны ли стрелки вперед if ($page != $total) $nextpage = ' > >>'; // Находим две ближайшие станицы с обоих краев, если они есть if($page - 2 > 0) $page2left = ' '. ($page - 2) .' | '; if($page - 1 > 0) $page1left = ''. ($page - 1) .' | '; if($page + 2 <= $total) $page2right = ' | '. ($page + 2) .''; if($page + 1 <= $total) $page1right = ' | '. ($page + 1) .''; // Вывод меню echo $pervpage.$page2left.$page1left.''.$page.''.$page1right.$page2right.$nextpage;

Важлива інформація

Міністерство оборони
України
з 24.02 по 14.05
втрати противника
орієнтовно склали:
969370 ( +1240 ) особового складу
10804 ( +2 ) танків
22501 ( +14 ) бойових бронемашин
27827 ( +47 ) артилерійських систем
1382 ( +1 ) РСЗВ
1165 ( +3 ) засоби ППО
372 ( +0 ) літаків
335 ( +0 ) гелікоптерів
48382 ( +126 ) автомобільної техніки
28 ( +0 ) кораблі / катери
3197 ( +0 ) крилаті ракети
35860 ( +82 ) БПЛА
3884 ( +0 ) спец. техніки
4 ( +0 ) установок ОТРК/ТРК
1 ( +0 ) підводні човни