Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. MySQL 5. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум PHP

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Не выводить пустые строки в постраничной навигации.
 
 автор: Костян   (30.08.2008 в 19:38)   письмо автору
 
 

добрый вечер! В какой-то теме видел, как можно сделать так, чтобы не выводились пустые строки при выводе списка из БД с постраничной навигацией, если на последней странице должно выйти сообщений меньше, чем заданное число сообщений на страницу. Весь вечер пытаюсь найти - не могу. Подскажите пожалуйста. Заранее благодарен.

  Ответить  
 
 автор: Trianon   (30.08.2008 в 19:59)   письмо автору
 
   для: Костян   (30.08.2008 в 19:38)
 

код покажите - тогда будет что менять.

  Ответить  
 
 автор: Костян   (30.08.2008 в 20:22)   письмо автору
 
   для: Trianon   (30.08.2008 в 19:59)
 

Соединение с базой:

<?php  
// Устанавливаем соединение с базой данных  
include "config.php";  
// Переменная хранит число сообщений выводимых на станице  
$num 25;  
// Извлекаем из URL текущую страницу  
$page $_GET['page'];  
// Определяем общее число сообщений в базе данных  
$result mysql_query("SELECT COUNT(*) FROM post");  
$posts mysql_fetch_row($result);  
// Находим общее число страниц  
$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))  
?> 

Вывод сообщений:

<?php  
echo "<table>";  
for(
$i 0$i $num$i++)  
{  
 echo 
"<tr> 
         <td>"
.$postrow[$i]['name']."</td> 
         <td>"
.$postrow[$i]['time']."</td></tr> 
       <tr><td colspan=\"2\">"
.$postrow[$i]['text']."</td></tr>";  
}  
echo 
"</table>";  
?> 


Навигация

<?php  
// Проверяем нужны ли стрелки назад  
if ($page != 1$pervpage '<a href= ./page?page=1><<</a>  
                               <a href= ./page?page='
. ($page 1) .'><</a> ';  
// Проверяем нужны ли стрелки вперед  
if ($page != $total$nextpage ' <a href= ./page?page='. ($page 1) .'>></a>  
                                   <a href= ./page?page=' 
.$total'>>></a>';  

// Находим две ближайшие станицы с обоих краев, если они есть  
if($page 0$page2left ' <a href= ./page?page='. ($page 2) .'>'. ($page 2) .'</a> | ';  
if(
$page 0$page1left '<a href= ./page?page='. ($page 1) .'>'. ($page 1) .'</a> | ';  
if(
$page <= $total$page2right ' | <a href= ./page?page='. ($page 2) .'>'. ($page 2) .'</a>';  
if(
$page <= $total$page1right ' | <a href= ./page?page='. ($page 1) .'>'. ($page 1) .'</a>'

// Вывод меню  
echo $pervpage.$page2left.$page1left.'<b>'.$page.'</b>'.$page1right.$page2right.$nextpage;  

?> 

  Ответить  
 
 автор: Trianon   (30.08.2008 в 20:27)   письмо автору
 
   для: Костян   (30.08.2008 в 20:22)
 

строка while ( $postrow[] = mysql_fetch_array($result))
должна быть заменена на
//<?
    
for($postrow = array() ,$num mysql_num_rows($result); 
         
$row mysql_fetch_assoc($result);
          
$postrow[] = $row) ;

  Ответить  
 
 автор: Костян   (30.08.2008 в 20:45)   письмо автору
 
   для: Trianon   (30.08.2008 в 20:27)
 

спасибо огромное!

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования