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

Форум PHP

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

 

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

вид форума:
Линейный форум (новые сообщения вниз) Структурный форум

тема: Дайте навигацию рабочую

Сообщения:  [1-10]   [11-14] 

 
 автор: ferz   (31.05.2006 в 18:34)   письмо автору
 
   для: Unkind™   (31.05.2006 в 17:47)
 

Спасибо всем, кто отвечал! Покопался я самостоятельно, проверил все переменные. Оказалось, что немного не так считается $posts. Вообщем, переделал, теперь все отлично работает. Выложу, мож кому интересно:

<?php
// Устанавливаем соединение с базой данных
include "connect.php";
// Переменная хранит число сообщений выводимых на станице
$num 1;
$pervpage="";
$nextpage="";
$page2left="";
$page1left="";
$page1right="";
$page2right="";
// Извлекаем из URL текущую страницу
$page $_GET['page'];
// Определяем общее число сообщений в базе данных
$result mysql_query("SELECT COUNT(*) as cnt FROM post");
$posts=mysql_result($result,0,"cnt");
// Находим общее число страниц
$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= ./post.php?page=1><<</a>
                               <a href= ./post.php?page='
. ($page 1) .'><</a> ';
// Проверяем нужны ли стрелки вперед
if ($page != $total$nextpage ' <a href= ./post.php?page='. ($page 1) .'>></a>
                                   <a href= ./post.php?page=' 
.$total'>>></a>';

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

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

?>

   
 
 автор: Unkind™   (31.05.2006 в 17:47)   письмо автору
 
   для: ferz   (31.05.2006 в 17:42)
 

<?php
#########
##Начало
#########
echo "<table>"
########################
##ТУТ ОШИБКА БЫЛА ВМЕСТО "=" нужно "=="
########################
while ($postrow == mysql_fetch_array($result)) 

echo 
"<tr> 
         <td>"
.$postrow['name']."</td> 
         <td>"
.$postrow['time']."</td></tr> 
       <tr><td colspan=\"2\">"
.$postrow['text']."</td></tr>"

echo 
"</table>"
##############
##Продолжение
##############
?>

   
 
 автор: ferz   (31.05.2006 в 17:42)   письмо автору
 
   для: kadet_73   (31.05.2006 в 16:12)
 

Попробовал, но ничего не изменилось. Ну что может быть???

   
 
 автор: kadet_73   (31.05.2006 в 16:12)   письмо автору
 
   для: ferz   (31.05.2006 в 15:09)
 

Попробуй заместо строчки $posts = mysql_fetch_row($result);
поставить $posts = mysql_num_rows($result);

   
 
 автор: ferz   (31.05.2006 в 15:09)   письмо автору
 
   для: ferz   (30.05.2006 в 13:13)
 

Ну подскажите, почему не работает!!!

   
 
 автор: ferz   (30.05.2006 в 13:13)   письмо автору
 
   для: Artem S.   (29.05.2006 в 15:57)
 

Все равно не работает. Пишет:
Notice: Undefined offset: 4 in z:\home\localhost\www\vestnik\post.php on line 33

Notice: Undefined offset: 4 in z:\home\localhost\www\vestnik\post.php on line 34

Notice: Undefined offset: 4 in z:\home\localhost\www\vestnik\post.php on line 35
Т.е. в этих строчках:

<td>".$postrow[$i]['name']."</td>
         <td>".$postrow[$i]['time']."</td></tr>
       <tr><td colspan=\"2\">".$postrow[$i]['text']."</td></tr>";

   
 
 автор: Artem S.   (29.05.2006 в 15:57)   письмо автору
 
   для: ferz   (29.05.2006 в 15:56)
 

$posts является массивом.
Следует переписат так.

$total = intval((sizeof($posts) - 1) / $num) + 1; 

   
 
 автор: ferz   (29.05.2006 в 15:56)   письмо автору
 
   для: ferz   (26.05.2006 в 14:18)
 

Ну помогите, кто знает

   
 
 автор: ferz   (26.05.2006 в 14:18)   письмо автору
 
   для: Smak   (25.05.2006 в 21:42)
 

Smak, мне бы хотелось, чтобы вывод ссылок был такого формата: << < ..2|3|<b>4</b>|5|6.. > >>
Вот тут есть на сайте такая навигация (статья). Взял ее, вот код, который я собрал:

<?php
// Устанавливаем соединение с базой данных
include "connect.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;

?>

Выдает следующую ошибку:
Fatal error: Unsupported operand types in z:\home\localhost\www\vestnik\post.php on line 12
Т.е. в строке:

$total = intval(($posts - 1) / $num) + 1;

Как исправить, чтоб заработало?

   
 
 автор: Artem S.   (26.05.2006 в 09:21)   письмо автору
 
   для: Vasil   (26.05.2006 в 05:58)
 

Скажем $files это файлы в папке. Чтобы из вывести на нескольких страницах:

<?php
$page 
abs((int)@$_GET['page']);
$files_on_page 10;
if (empty(
$page)) {
    
$page 1;
}
$d dir('.');
while (
false !== ($entry $d->read())) {
    if (
is_file($file)) {              
            
$files[] = $entry;
    }   
}
$d->close();
$vars   navigation(sizeof($files), $page$files_on_page'index.php'); 
$offset $files_on_page*($page-1);
$files  array_slice($files$offset$files_on_page); 
?>


<?for($i=0$size=sizeof($files); $i<$size$i++): ?>
<?=$files
[$i]?><br />
<?forend?>

<p class="navi" style="text-align:center">
<?=$vars['start']?>
<?=$vars
['prev']?>
<?=$vars
['cur']?>
(<?=$vars['total']?>)
<?=$vars['next']?>
<?=$vars
['end']?>
</p> 

   

Сообщения:  [1-10]   [11-14] 

Форум разработан IT-студией SoftTime
Rambler's Top100
вверх

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