WordPress как на ладони
Недорогой хостинг для сайтов на WordPress: wordpress.jino.ru

the_posts_pagination() WP 4.1.0

Выводит на экран ссылки пагинации на след./пред. сет постов. Используется на страницах архивов (рубрики, метки, ...).

ссылки пагинации в теме Twenty Fifteen

Функция рассчитана на использования с любым типом записей.

Чтобы получить результат для обработки, используйте get_the_posts_pagination().

Работает на основе: get_the_posts_pagination()

Хуков нет.

Возвращает

Ничего. Выводит на экран HTML код пагинации. Если страниц пагинации нет (меньше 1), то ничего не выведет.

Использование

the_posts_pagination( $args );
$args(массив)

Параметры по которым будет выводиться результат. По умолчанию:

$args = array(
	'show_all'     => false, // показаны все страницы участвующие в пагинации
	'end_size'     => 1,     // количество страниц на концах
	'mid_size'     => 1,     // количество страниц вокруг текущей
	'prev_next'    => true,  // выводить ли боковые ссылки "предыдущая/следующая страница".
	'prev_text'    => __('« Previous'),
	'next_text'    => __('Next »'),
	'add_args'     => false, // Массив аргументов (переменных запроса), которые нужно добавить к ссылкам.
	'add_fragment' => '',     // Текст который добавиться ко всем ссылкам.
	'screen_reader_text' => __( 'Posts navigation' ),
);

$args передается в функцию paginate_links(), поэтому полный список параметров, смотрите в её описании.
По умолчанию: предустановки

Примеры

#1 Вывод пагинации на экран

<?php the_posts_pagination(); ?>

Выведет:

<nav class="navigation pagination" role="navigation">
	<h2 class="screen-reader-text">Навигация по записям</h2>
	<div class="nav-links"><span class="page-numbers current"><span class="meta-nav screen-reader-text">Страница </span>1</span>
		<a class="page-numbers" href="http://wptest.ru/page/2/"><span class="meta-nav screen-reader-text">Страница </span>2</a>
		<span class="page-numbers dots">…</span>
		<a class="page-numbers" href="http://wptest.ru/page/86/"><span class="meta-nav screen-reader-text">Страница </span>86</a>
		<a class="page-numbers" href="http://wptest.ru/page/87/"><span class="meta-nav screen-reader-text">Страница </span>87</a>
		<a class="next page-numbers" href="http://wptest.ru/page/2/">Следующая страница</a>
	</div>
</nav>

Ссылки пагинации в теме Twenty Fifteen

#2 Управление отображением

По умолчанию the_posts_pagination() выводит первую и последнюю страницу и по одной странице около текущей. Остальные заменяются многоточием. Этот вывод можно изменить с помощью аргументов:

show_all — показывать все страницы
end_size — количество страниц в начале и конце списка
mid_size — количество страниц слева и справа от текущей страницы

<?php 
the_posts_pagination( array(
	'mid_size' => 2,
) ); 
?>

Ссылки пагинации в теме Twenty Fifteen

#2.1 параметр end_size

Установим 2 ссылки на последние страницы в пагинации:

<?php 
the_posts_pagination( array(
	'end_size' => 2,
) ); 
?>

Ссылки пагинации в теме Twenty Fifteen

#3 Удаляем заголовок H2 из шаблона

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

С точки зрения SEO этот тег, вроде бы, лучше убрать. Сделать это можно с помощью фильтра navigation_markup_template:

// удаляет H2 из шаблона пагинации
add_filter('navigation_markup_template', 'my_navigation_template', 10, 2 );
function my_navigation_template( $template, $class ){
	/*
	Вид базового шаблона:
	<nav class="navigation %1$s" role="navigation">
		<h2 class="screen-reader-text">%2$s</h2>
		<div class="nav-links">%3$s</div>
	</nav>
	*/

	return '
	<nav class="navigation %1$s" role="navigation">
		<div class="nav-links">%3$s</div>
	</nav>    
	';
}

// выводим пагинацию
the_posts_pagination( array(
	'end_size' => 2,
) ); 

Список изменений

С версии 4.1.0 Введена.

Код the posts pagination: wp-includes/link-template.php WP 5.4.1

<?php
function the_posts_pagination( $args = array() ) {
	echo get_the_posts_pagination( $args );
}

Cвязанные функции

Из метки: navigation pagination (навигация пагинация)

Еще из раздела: Архивы

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

    Ответить24.Сен.2017 12:41 #
    • Kama7725

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

      Думаю, проще придумать другой подход. Например, сворачивать описание и разворачивать по клику на кнопку - кому надо кликнут прочитают...

      2
      Ответить25.Сен.2017 02:39 #
  • Виталий

    Добрый день. Помогите решить проблему.Вывожу навигацию в категориях с помощью the_posts_pagination($args);
    В конце URL первой страницы появляется слеш. Как можно его убрать, чтобы избежать дублей страниц.
    Пробовал untrailingslashit не помогло.

    1
    Ответить14.Мар.2018 03:20 #
  • Добрый день !

    Та же проблема со слешем

    Как убрть вывод слеша на конце адреса в пагинации ?

    На сайте прописан редирект со всех страниц со слешем "/" на конце на адреса без него.

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

    ссылка на первую страницу имеет слеш на конце

    сайт.ру/название рубрики/

    есть ли какое либо решение для вставки в functions.php ?

    Ответить11.Апр.2018 19:24 #
    • @ campusboy3532 www.youtube.com/c/wpplus

      Привет. По ходу баг. Спасибо за репорт. Кинул тикет на трек.

      1
      Ответить18.Апр.2018 00:38 #
    • @ Алексей

      У меня редирект со слеша на без слеша на конце. При выводе результатов фильтра по произвольным полям тоже не работала пагинация: к ссылке на первую страницу добавлялся слеш (https://site.ru/filter/?..., а должно было быть https://site.ru/filter?...) и в итоге выдавало 404 ошибку, причем только на 1-ю страницу. Помог вот такой вариант:

      <?
      the_posts_pagination(array(
      	'base'         => 'https://site.ru/filter%_%',
      	'format'       => '/page/%#%',
      	'prev_text'    => __('«'),
      	'next_text'    => __('»'),
      	'screen_reader_text' => __( '' ),
      	)
      ); 
      ?>
      Ответить3.Июл.2018 15:59 #
  • Тимур привет!
    Подскажи, пожалуйста, как можно вывести пагинацию в Woo при выводе товаров со Скидкой через шорткод ([sale_products per_page=""])? scratch_one-s_head
    На данный момент, выводит все одной простыней, когда указываешь кол-во 20 ([sale_products per_page="20"]), выводит только 20, остальные товары обрезает и не выводит хотя их больше.

    Спасибо!

    Ответить26.Июн.2018 22:47 #
  • Максим

    Спасибо автору, помог good

    Ответить26.Фев.2019 18:56 #
  • Подскажите, пожалуйста, как вывести эту пагинацию или какую-либо на кастомном типе записи?
    Создал кастомные типы записи, не знаю как вывести пагинацию. Когда вставляю

    <?php the_posts_pagination(); ?>

    Ничего не выводит, в инспекторе никакого кода связанного с пагинацией - нет.

    5
    Ответить18.Авг.2019 00:38 #
  • Здравствуйте, у меня появилась такая ошибка
    "Warning: count(): Parameter must be an array or an object that implements Countable in "
    Можете подсказать, что с этим делать ?

    Ответить27.Авг.2019 18:26 #
  • Bitroniks tiflohelp.ru

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

    Ответить6.Апр.2020 16:29 #