Перейти до вмісту
Пошук в
  • Детальніше...
Шукати результати, які ...
Шукати результати в ...

Пагинация в модуле Рекомендуемые товары


Recommended Posts

Доброго времени суток всем.

OpenCart 1.5.4.1.

Решил сделать пагинацию в модуле "Рекомендуемые товары" (featured - англ.). В файле контроллера категории подсмотрел соответствующий код, вот что у меня получилось в итоге:

if (isset($this->request->get['page'])) {
                $page = $this->request->get['page'];
            } else {
                $page = 1;
            }
            
            print_r($page);
            
            $data = array(
                'start' => ($page - 1) * 2,
                'limit' => 2
            );
            $get_total_records = $this->model_catalog_product->getTotalProducts($data);
                    
            $pagination = new Pagination();

            $url = '';
            $pagination = new Pagination();
            $pagination->total = $get_total_records;
            $pagination->page = $page;
            $pagination->limit = 2;
            $pagination->text = $this->language->get('text_pagination');
            $pagination->url = $this->url->link('common/home', 'token=' . $this->session->data['token'] . $url . '&page={page}', 'SSL');
            
            $this->data['pagination'] = $pagination->render();

Ну и соотвественно вывел заглушку в файле шаблона:

<?php echo $pagination; ?>

Пагинация в модуле появляется + отображение в пагинации правильное, но на каждой стр. 1...2....3...4 выводятся все товары модуля!!! Подскажите как победить??

Надіслати
Поділитися на інших сайтах


Вывести пагинацию - полдела. Теперь отлавливайте номер страницы и выводите данные согласно ее.

Надіслати
Поділитися на інших сайтах

  • 2 months later...

також потрібно поправити файл моделі (робота з БД)

Ви передали

$data = array(

'start' => ($page - 1) * 2,

'limit' => 2

);

$get_total_records = $this->model_catalog_product->getTotalProducts($data); - дивимось функцію файлу моделі

і тут в умові витягнення з БД треба поставити

LIMIT " . (int)$data['start'] . "," . (int)$data['limit'] );

в результаті отримаєте саме ті позиції, які мають бути на конкретній сторінці

Надіслати
Поділитися на інших сайтах


Створіть аккаунт або увійдіть для коментування

Ви повинні бути користувачем, щоб залишити коментар

Створити обліковий запис

Зареєструйтеся для отримання облікового запису. Це просто!

Зареєструвати аккаунт

Вхід

Уже зареєстровані? Увійдіть тут.

Вхід зараз

×
×
  • Створити...

Important Information

На нашому сайті використовуються файли cookie і відбувається обробка деяких персональних даних користувачів, щоб поліпшити користувальницький інтерфейс. Щоб дізнатися для чого і які персональні дані ми обробляємо перейдіть за посиланням . Якщо Ви натиснете «Я даю згоду», це означає, що Ви розумієте і приймаєте всі умови, зазначені в цьому Повідомленні про конфіденційність.