WordPress как на ладони
WordCamp Saint Petersburg 2018 wordpress jino

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,
) ); 

Код the posts pagination: wp-includes/link-template.php VER 4.9.5

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

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

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

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

the_posts_pagination 36 комментов
Полезные 3 Вопросы 2 Все
  • Михаил

    Доброго времени суток! Такая проблема:
    Вывожу произвольный тип постов методом query_posts()
    Внизу подключаю ajax пагинацию, всё работает и на статических страницах, и в архивах.
    А на главной странице загружает точно такие же записи. Подскажите, пожалуйста, как можно исправить.
    Код:

     $args = array( 'post_type' => 'custom-type', 'posts_per_page' => 8, 'order' => 'DESC', 'page' => get_query_var('paged'), );
    		query_posts($args);
    		while ( have_posts() ) : the_post();
    
    			get_template_part( 'content-reading', get_post_format() );  
    
    	 endwhile; 
    		 echo ''; echo next_posts_link(__('Показать ещё')); echo '';
    	wp_reset_query();
    1
  • Сергей

    Не могу поставить навигацию на главную страницу блога
    В чем может быть проблема?

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

    • Kama5188

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

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

  • По моему, нужно указать, что функция работает только со стандартными записями, с произвольным типом записей нужно использовать другую функцию. Если это не так, исправьте...

    Ответить3 месяца назад #
  • Виталий

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

    1
    Ответитьмесяц назад #
  • Добрый день !

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

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

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

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

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

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

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

    Ответить12 дней назад #

Здравствуйте, !

Ваш комментарий
Предпросмотр