0 / 0 / 1
Регистрация: 12.03.2013
Сообщений: 16

Paginator PHP не коректный запрос при возрате на страницу

02.03.2017, 08:31. Показов 704. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В учебных целях пытаюсь реализовать сайт на MVC с фронт контроллером. Добавил paginator для навигации по страницам. При попытке перейти со 2-ой страницы, обратно на 1-ую в запросе получаю следующее: http://localhost/blog/page2/page1
Без пейджинатора была точно такая же проблема, решал ее добавлением слэша перед запросом(<a href='/blog/page1'>)
Подскажите в чем может быть проблема. В видео-уроках этот пейджинатор работает как положено .

Pagination.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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
<?php
 
/*
 * Класс для генерации постраничной навигации
 */
 
class Pagination
{
 
    /**
     * 
     * @var Ссылок навигации на страницу
     * 
     */
    private $max = 10;
 
    /**
     * 
     * @var Ключ для GET, в который пишется номер страницы
     * 
     */
    private $index = 'page';
 
    /**
     * 
     * @var Текущая страница
     * 
     */
    private $current_page;
 
    /**
     * 
     * @var Общее количество записей
     * 
     */
    private $total;
 
    /**
     * 
     * @var Записей на страницу
     * 
     */
    private $limit;
 
    /**
     * Запуск необходимых данных для навигации
     * @param integer $total - общее количество записей
     * @param integer $limit - количество записей на страницу
     * 
     * @return
     */
    public function __construct($total, $currentPage, $limit, $index)
    {
        # Устанавливаем общее количество записей
        $this->total = $total;
 
        # Устанавливаем количество записей на страницу
        $this->limit = $limit;
 
        # Устанавливаем ключ в url
        $this->index = $index;
 
        # Устанавливаем количество страниц
        $this->amount = $this->amount();
 
        # Устанавливаем номер текущей страницы
        $this->setCurrentPage($currentPage);
    }
 
    /**
     *  Для вывода ссылок
     * 
     * @return HTML-код со ссылками навигации
     */
    public function get()
    {
        # Для записи ссылок
        $links = null;
 
        # Получаем ограничения для цикла
        $limits = $this->limits();
 
        $html = '<ul class="pagination">';
        # Генерируем ссылки
        for ($page = $limits[0]; $page <= $limits[1]; $page++) {
            # Если текущая это текущая страница, ссылки нет и добавляется класс active
            if ($page == $this->current_page) {
                $links .= '<li class="active"><a href="#">' . $page . '</a></li>';
            } else {
                # Иначе генерируем ссылку
                $links .= $this->generateHtml($page);
            }
        }
 
        # Если ссылки создались
        if (!is_null($links)) {
            # Если текущая страница не первая
            if ($this->current_page > 1)
            # Создаём ссылку "На первую"
                $links = $this->generateHtml(1, '&lt;') . $links;
 
            # Если текущая страница не первая
            if ($this->current_page < $this->amount)
            # Создаём ссылку "На последнюю"
                $links .= $this->generateHtml($this->amount, '&gt;');
        }
 
        $html .= $links . '</ul>';
 
        # Возвращаем html
        return $html;
    }
 
    /**
     * Для генерации HTML-кода ссылки
     * @param integer $page - номер страницы
     * 
     * @return
     */
    private function generateHtml($page, $text = null)
    {
        # Если текст ссылки не указан
        if (!$text)
        # Указываем, что текст - цифра страницы
            $text = $page;
 
        $currentURI = rtrim($_SERVER['REQUEST_URI'], '/') . '/';
        $currentURI = preg_replace('~/page-[0-9]+~', '', $currentURI);
        # Формируем HTML код ссылки и возвращаем
        return
                '<li><a href="' . $currentURI . $this->index . $page . '">' . $text . '</a></li>';
    }
 
    /**
     *  Для получения, откуда стартовать
     * 
     * @return массив с началом и концом отсчёта
     */
    private function limits()
    {
        # Вычисляем ссылки слева (чтобы активная ссылка была посередине)
        $left = $this->current_page - round($this->max / 2);
 
        # Вычисляем начало отсчёта
        $start = $left > 0 ? $left : 1;
 
        # Если впереди есть как минимум $this->max страниц
        if ($start + $this->max <= $this->amount)
        # Назначаем конец цикла вперёд на $this->max страниц или просто на минимум
            $end = $start > 1 ? $start + $this->max : $this->max;
        else {
            # Конец - общее количество страниц
            $end = $this->amount;
 
            # Начало - минус $this->max от конца
            $start = $this->amount - $this->max > 0 ? $this->amount - $this->max : 1;
        }
 
        # Возвращаем
        return
                array($start, $end);
    }
 
    /**
     * Для установки текущей страницы
     * 
     * @return
     */
    private function setCurrentPage($currentPage)
    {
        # Получаем номер страницы
        $this->current_page = $currentPage;
 
        # Если текущая страница боле нуля
        if ($this->current_page > 0) {
            # Если текунщая страница меньше общего количества страниц
            if ($this->current_page > $this->amount)
            # Устанавливаем страницу на последнюю
                $this->current_page = $this->amount;
        } else
        # Устанавливаем страницу на первую
            $this->current_page = 1;
    }
 
    /**
     * Для получеия общего числа страниц
     * 
     * @return число страниц
     */
    private function amount()
    {
        # Делим и возвращаем
        return round($this->total / $this->limit);
    }
 
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
02.03.2017, 08:31
Ответы с готовыми решениями:

SQL Запрос с выводом на php страницу
Добрый вечер, можете подсказать в чем ошибка? Данный запрос по идее должен вывести на страницу сколько раз встречается в БД слово Классика...

при запросе вида «script.php?id=ЗАПРОС» выводить статью под номером «ЗАПРОС»
Написать php-скрипт, который при запросе вида «script.php?id=ЗАПРОС» будет выводить в браузер статью, хранящуюся в базе под номером...

Создать php страницу через другую php страницу
Всем привет. Я пытаюсь написать страницу, которая по заданному шаблону должна создавать другие страницы на сервере. Вот её код: ...

1
Эксперт PHP
5755 / 4134 / 1508
Регистрация: 06.01.2011
Сообщений: 11,276
02.03.2017, 08:53
Ой, а это мой пагинатор. Правда дополненный. Кто-то его даже в видеоуроках использует.
У меня номер страницы обычным параметром передавался:
http://site.ru/?page=1
Вот тут он в исходном виде: Обмен готовыми решениями
Только тогда я над стандартами не думал, поэтому под PSR код не подходит. С тех пор несколько переработал его.

Кстати, рекомендую использовать именно в исходном. Так как подобное указание страниц:
http://site.ru/page1
не очень удобно, да и с маршрутизатором могут быть проблемы.

Если всё же хотите использовать этот -- замените
PHP
1
$currentURI = preg_replace('~/page-[0-9]+~', '', $currentURI);
на
PHP
1
$currentURI = preg_replace('~/page\d+~', '', $currentURI);
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.03.2017, 08:53
Помогаю со студенческими работами здесь

Возвращает булевое значение, запрос при переходе на другую страницу
Есть код. Код кривой, да.... Но я разбираюсь пока, что только...... &lt;meta http-equiv='refresh' content='10';...

Создать страницу при помощи PHP на двух языках
Добрый вечер. Я столкнулся с небольшой проблемой. Хотел создать страницу при помощи PHP на 2-х языках, то есть чтобы было 2 кнопки:...

При выполнение php надо обновить страницу по другому url?
Есть кнопка ВХОД при нажатии на неё нужно чтобы 1)открылась другая страница , а эта закрылась либо 2) обновилась страница на другую...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru