Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
6 / 6 / 1
Регистрация: 26.12.2013
Сообщений: 352

Пагинация

25.04.2017, 10:59. Показов 1070. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пытаюсь уже второй день разобраться с пагинацией на сайте, все разные ошибки выскакивают... Создал отдельный файл navigation.php. В нем, в данный момент прописал следующее:

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<?php require_once 'models/function.php'; ?> // подключаю функции
// код
<?php 
 
// Навигация
$page = $_GET['page'];
if (($page < 1) or ($page == "")) $page = 1; // если page меньше 1 или равен строке, то выводим 1. 
echo $page;
$limit = 5; 
$start = getStart($page, $limit);
$articles = getAllArticles($start, $limit);
for ($i = 0; $i < count($articles); $i++) echo $articles [$i]["title"];
echo $pagination($page, $limit )
 
?>
// Шаблон пагинации
<nav>
    <ul class="pagination blog-pagination">
                <li>
                    <a href="#" aria-label="Previous">
                        <span aria-hidden="true">«</span>
                    </a>
                </li>
            <li><a href="#">1</a></li>
            <li><a href="#">2</a></li>
            <li><a href="#">3</a></li>
            <li><a href="#">4</a></li>
            <li><a href="#">5</a></li>
      <li>
        <a href="#" aria-label="Next">
            <span aria-hidden="true">»</span>
        </a>
      </li>
    </ul>
</nav>
function.php:
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
<?php 
require_once 'config.php'; // подключаюсь к базе ( чтобы по сто раз не прописывать одно и тоже )
 
function getALLArticles($start, $limit){
        $result = mysql_query("SELECT * FROM 'articles' LIMIT".$start ",".$limit);
        return resultSetArray($result);
    }
    
    function resultSetToArray($result){
        $array = array();
        while ($row = mysql_fetch_assoc($result)) $array[] = $row;
        return $array;
    }
    function countArticles(){
        $result = mysql_query("SELECT COUNT('id') FROM 'articles'");
        $resuly = mysql_fetch_row($result);
        retunr $result[0];
    }
    function getStart($page, $limit){
        return $limit * ($page - 1);
    }
    function pagination($page, $limit){
        $count_articles = countArticles();
        $count_pages = ceil($count_articles / $limit);
        if ($page > $count_pages) $page = count_pages;
        $prev = $page - 1;
        $next = $page + 1;
        if ($prev < 1) $prev = 1;
        if (next > $count_pages) $next = $count_pages;
        $pagination = "";
        if ($count_pages > 1){
            if ($page == 1){
                $pagination .= "<span>Первая<span>";
                $pagination .= "<span>Предыдущая</span>";
            }
            else {
                $pagination .= "<a href='index.php'>Первая</a>";
                    if ($pref == 1) $pagination .= "<a href='index.php'>Первая</a>";
                else {
                    $pagination .= "<a href='index.php?page=".$prev."'>Предыдущая</a>";
                }
                for ($i = 1; $i <= $count_pages; $i++){
                    if ($i == 1) $pagination .= "<a href='index.php'>".$i."</a>";
                    elseif ($i == $page) $pagination .= "<span>".$i."</span>";
                    else $pagination .= "<a href='index.php?page=".$i."'>".$i."</a>";
                }
                
                if ($page == $count_pages){
                    $pagination .= "<span>Следующая</span>";
                    $pagination .= "<span>Последняя</span>";
                }
                else{
                    $pagination .= "a href='index.php?page=".$next."'>Следующая</a>"; 
                    $pagination .= "a href='index.php?page=".$count_page."'>Последняя</a>"
                }
                
            }
        }
        return $pagination;
    }
?>
И пока-что такая ошибка Parse error: syntax error, unexpected T_CONSTANT_ENCAPSED_STRING in V:\home\blogv2.lv\www\models\function.ph p on line 5 . Если убираю ",", то Parse error: syntax error, unexpected '.' in V:\home\blogv2.lv\www\models\function.ph p on line 5

Подскажите, пожалуйста, как исправить? И правильно ли вообще делаю пагинацию?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.04.2017, 10:59
Ответы с готовыми решениями:

Пагинация
Всем привет, делаю пагинацию всё как-бы ничего работает как задумал, кроме одного момента, на странице работает живой поиск.. Вот с ним...

Пагинация
Здравствуйте. Помогите кому не трудно сделать переключатель страниц. &lt;?php $ordtype = 'title'; $tb =...

Пагинация
Здравствуйте! Имею код вывода всех зарегистрированных пользователей: &lt;?php include 'header.html'; ?&gt; &lt;table&gt; ...

3
Эксперт PHP
5755 / 4134 / 1508
Регистрация: 06.01.2011
Сообщений: 11,276
25.04.2017, 11:26
PHP
1
mysql_query("SELECT * FROM 'articles' LIMIT".$start ",".$limit);
>>>>
PHP
1
mysql_query("SELECT * FROM `articles` LIMIT {$start}, {$limit}");
А вообще -- возьмите что-то вроде этого: https://github.com/Para-bellum/Parabellum
0
6 / 6 / 1
Регистрация: 26.12.2013
Сообщений: 352
25.04.2017, 16:08  [ТС]
Прописал так:
PHP
1
"SELECT * FROM 'articles' LIMIT ".$start.", ".$limit
- ошибка исчезла. Подправил все остальные ошибки. Теперь проблема в том, что на главной странице все ровно отображаются все статьи из базы, и в обратном порядке по ID. То есть, с 24 по 1. На первом месте 24 статья, на последнем - первая. Почему пагинация не закрывает все статьи кроме первых 5-ти по условию $limit = 5; ?

И как теперь можно в этот код впихнуть код, чтобы при нажатии был переход на первую статью и так далее?
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<nav>
    <ul class="pagination blog-pagination">
                <li>
                    <a href="#" aria-label="Previous">
                        <span aria-hidden="true">&laquo;</span>
                    </a>
                </li>
            <li><a href="#">1</a></li>
            <li><a href="#">2</a></li>
            <li><a href="#">3</a></li>
            <li><a href="#">4</a></li>
            <li><a href="#">5</a></li>
      <li>
        <a href="#" aria-label="Next">
            <span aria-hidden="true">&raquo;</span>
        </a>
      </li>
    </ul>
</nav>
Добавлено через 3 часа 17 минут
Сейчас проблема с функцией resultSetArray:
Fatal error: Call to undefined function resultSetArray() in V:\home\blogv2.lv\www\models\function.ph p on line 6

Что ему не нравится?

Code
1
2
3
4
function getALLArticles($start, $limit){
        $result = mysql_query("SELECT * FROM 'articles' LIMIT ".$start.", ".$limit);
        return resultSetArray($result);
}
Добавлено через 1 час 13 минут
С той функцией тоже разобрался.
Теперь следующая проблема:
PHP
1
2
3
 Warning: mysql_fetch_assoc() expects parameter 1 to be resource, boolean given in V:\home\blogv2.lv\www\models\function.php on line 11
 
Fatal error: Function name must be a string in V:\home\blogv2.lv\www\views\navigation.php on line 11
0
930 / 846 / 190
Регистрация: 28.11.2013
Сообщений: 3,621
25.04.2017, 17:19
Grep1994, вам нужно двигаться от простого к сложному, а не наоборот. Такое ощущение, что вы весь код набрали на коленке, а только потом стали его запускать. Последняя ошибка связана с тем, что вы не проверяете $result, а почему у вас в $result не то, что вы ожидали, см. там, где получаете соотв. значение.

Основы пагинации от меня: Как сделать пагинацию?
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.04.2017, 17:19
Помогаю со студенческими работами здесь

Не работает пагинация
Не работает пагинатор, при переходе на другую страницу, в строке меняется номер страницы, а на самой станице остается содержание первой...

Пагинация на сайте
есть код, работает хорошо, только вот он выводит все страницы, а мне нужно что бы если допустим я на 3-й, то выводило одну предыдущую и...

Пагинация на сайте
Здравствуйте. Есть пагинация. Выглядит она вот так: Первая 1 2..Последняя &gt;&gt; Как сделать так, чтоб вместо слово последняя выводился...

Пагинация на сайте
Помогите сделать пагинацию на сайт , есть база данных она выводит все базу , надо что бы выводила первые 100 значений , а потом при нажатии...

Пагинация без БД
Здравствуйте. Ох, пагинация без БД это сложно, но мне нужна помощь. Нужно сделать пагинацию без БД. Чтобы легче было, у меня есть...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru