Просмотр файла java/textfile.txt

Размер файла: 3.81Kb
  1. php_5.txt
  2.  
  3. ----------
  4.  
  5. Постраничная навигация
  6. Проблема реализации постраничной навигации часто встает перед начинающими PHP-программистами. К разбиению объёмного текста на отдельные страницы прибегают во многих Web-приложениях от гостевых книг и форумов до различных каталогов. Давайте
  7. решим эту проблему.
  8. Итак, что нам требуется для реализации постраничной навигации? Для примера возьмем гостевую книгу, содержащую несколько сотен сообщений, в которой требуется выводить на страницу Х сообщений.
  9. Рассмотрим задачу более конкретно. Сообщения пользователей хранятся в базе данных post со следующей структурой:
  10. id номер сообщения,
  11. text тело сообщения,
  12. name имя автора,
  13. time время создания.
  14.  
  15. В итоге нам надо получить вывод Х сообщений на страницу, а также организовать удобную навигацию, например, такую:
  16.  
  17. << < ..2|3|<b>4</b>|5|6.. > >>
  18.  
  19. где 4 - текущая станица. Для того чтобы отслеживать текущую страницу, будем использовать параметр page, передаваемый через URL. К примеру:
  20.  
  21. www.myserver.com/index.php?page=X.
  22.  
  23. Здесь X - номер станицы (для примера, пусть Х будет равно 25).
  24.  
  25. Теперь, после этого небольшого введения, можно приступать к непосредственной реализации.
  26.  
  27. <?php
  28. // Устанавливаем соединение с базой данных
  29. include "config.php";
  30. // Переменная хранит число сообщений выводимых на станице
  31. $num = 25;
  32. // Извлекаем из URL текущую страницу
  33. $page = $_GET['page'];
  34. // Определяем общее число сообщений в базе данных
  35. $result = mysql_query("SELECT COUNT(*) FROM post");
  36. $posts = mysql_fetch_row($result);
  37. // Находим общее число страниц
  38. $total = intval(($posts - 1) / $num) + 1;
  39. // Определяем начало сообщений для текущей страницы
  40. $page = intval($page);
  41. // Если значение $page меньше единицы или отрицательно
  42. // переходим на первую страницу
  43. // А если слишком большое, то переходим на последнюю
  44. if(empty($page) or $page < 0) $page = 1;
  45. if($page > $total) $page = $total;
  46. // Вычисляем начиная к какого номера
  47. // следует выводить сообщения
  48. $start = $page * $num - $num;
  49. // Выбираем $num сообщений начиная с номера $start
  50. $result = mysql_query("SELECT * FROM post LIMIT $start, $num");
  51. // В цикле переносим результаты запроса в массив $postrow
  52. while ( $postrow[] = mysql_fetch_array($result))
  53. ?>
  54.  
  55. На этом первая часть закончена. Двумерный массив postrow хранит все поля таблицы post, необходимые для отображения станицы. Вот пример как можно организовать вывод сообщений.
  56.  
  57. <?php
  58. echo "<table>";
  59. for($i = 0; $i < $num; $i++)
  60. {
  61. echo "<tr>
  62. <td>".$postrow[$i]['name']."</td>
  63. <td>".$postrow[$i]['time']."</td></tr>
  64. <tr><td colspan=\"2\">".$postrow[$i]['text']."</td></tr>";
  65. }
  66. echo "</table>";
  67. ?>
  68.  
  69. Теперь надо организовать навигацию. Формируем составляющие будущей навигации.
  70. Коды стрелки «в начало» и «назад» поместим в одну переменную, также поступим и со стрелками «в конец» и «вперед».
  71.  
  72. <?php
  73. // Проверяем нужны ли стрелки назад
  74. if ($page != 1) $pervpage = '<a href= ./page?page=1><<</a>
  75. <a href= ./page?page='. ($page - 1) .'><</a> ';
  76. // Проверяем нужны ли стрелки вперед
  77. if ($page != $total) $nextpage = ' <a href= ./page?page='. ($page + 1) .'>></a>
  78. <a href= ./page?page=' .$total. '>>></a>';
  79.  
  80. // Находим две ближайшие станицы с обоих краев, если они есть
  81. if($page - 2 > 0) $page2left = ' <a href= ./page?page='. ($page - 2) .'>'. ($page - 2) .'</a> | ';
  82. if($page - 1 > 0) $page1left = '<a href= ./page?page='. ($page - 1) .'>'. ($page - 1) .'</a> | ';
  83. if($page + 2 <= $total) $page2right = ' | <a href= ./page?page='. ($page + 2) .'>'. ($page + 2) .'</a>';
  84. if($page + 1 <= $total) $page1right = ' | <a href= ./page?page='. ($page + 1) .'>'. ($page + 1) .'</a>';
  85.  
  86. // Вывод меню
  87. echo $pervpage.$page2left.$page1left.'<b>'.$page.'</b>'.$page1right.$page2right.$nextpage;
  88.  
  89. ?>
  90.  
  91. http://test1.ru