Я попытался создать нумерацию страниц на своем веб-сайте, используя пакет KnpPaginator.
В моем хранилище я создаю запрос:
public function getProductsOrderByDateDesc($id_category = null, $max = null){
$qb = $this->createQueryBuilder('p')
->orderBy('p.created_at', 'DESC');
if($max) {
$qb->setMaxResults($max);
}
if($id_category) {
if(is_array($id_category)){
$aIdCategory = implode("','",$id_category);
$qb->andWhere('p.category IN (:ids)')
->setParameter('ids', $aIdCategory);
}else{
$qb->andWhere('p.category = :category_id')
->setParameter('category_id', $id_category);
}
}
$query = $qb->getQuery();
return $query->getArrayResult();
}
В моем контроллере я делаю:
$repositoryProduct = $em->getRepository('ShopDesktopBundle:Product');
$aProducts = array();
$aProducts = $repositoryProduct->getProductsOrderByDateDesc($id);
$paginator = $this->get('knp_paginator');
$pagination = $paginator->paginate(
$aProducts,
$this->get('request')->query->get('page', 1),
3
);
return $this->render('ShopDesktopBundle:Category:category.html.twig',array(
'aProducts' => $aProducts,
'pagination' => $pagination
));
В связи с этим я показываю только эту нумерацию страниц:
<div class="navigation">
{{ knp_pagination_render(pagination) }}
</div>
Проблема в том, что всегда отображаются все продукты, а не только предел, который для моего примера равен 3.
Например :
У меня 9 товаров, limit = 3, нумерация страниц правильная «1 2 3», но для каждой страницы я вижу все 9 товаров
Помоги мне, пожалуйста ! Спасибо заранее
Почти правильно, однако вы должны использовать объект нумерации страниц вместо «aProducts». На ваш взгляд, используйте следующий код:
{% for product in pagination %}
<tr {% if loop.index is odd %}class="color"{% endif %}>
<td>{{ product.id }}</td>
<td>{{ product.title }}</td>
</tr>
{% endfor %}
Смотрите больше информации в документации, под «View»: https://github.com/KnpLabs/KnpPaginatorBundle
Других решений пока нет …