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

Пагинация

25.04.2017, 10:59. Показов 1060. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru