next_post_link()
Выводит ссылку на следующую по дате запись. Используется на страницах типа is_single()
.
Работает с global $post
.
Работает на основе: get_next_post_link()
Хуков нет.
Использование
<?php next_post_link( $format, $link, $in_same_cat, $excluded_terms, $taxonomy ); ?>
- $format(строка)
- Формат ссылки. Контролирует что будет до и после ссылки. Тег %link в строке будет заменен на ссылку. Например, ‘Перейти к %link’, выведет Перейти к Название статьи. Также в строке можно использовать параметр %date, тогда в текст ссылки будет добавлена еще и дата публикации поста.
По умолчанию: ‘%link »’ - $link(строка)
- Текст ссылки (Анкор). Тег %title будет заменен заголовком статьи.
По умолчанию: ‘%title’ - $in_same_cat(логический)
- Если установить этот параметр в true или 1, то будет выводиться ссылка на следующую статью из той же категории что и текущая.
По умолчанию: false - $excluded_terms (строка)
- ID категории посты из которых не нужно учитывать при подборе следующего поста. Можно указать несколько категорий. Указывать можно:
- в массиве — ‘1,5,15’
- через запятую — array(1,5,15)
- через слово and — ‘1 and 5 and 15’
Если указан следующий параметр
$taxonomy
, то тут нужно указывать соответствующие термины термины.Параметр не работает для постоянных страниц (page) и типов записей у которых нет таксономий.
По умолчанию: нет
- $taxonomy(строка)
- Название таксономии ссылка на запись из которой будет получаться.
По умолчанию: ‘category’
Примеры
#1 Следующая ссылка
Выведем следующую по дате публикации ссылку и выделим её жирным (HTML тегом strong):
<?php next_post_link('<strong>%link</strong>'); ?>
Вернет: <a rel="next" href="/post_name">Заголовок поста</a>
#2 Из текущей категории
Выведем ссылку на следующую статью из текущей категории с текстом — «Следующая статья из категории» вместо заголовка статьи:
<?php next_post_link('%link', 'Следующая статья из категории', true); ?>
#3 Исключим категорию
Выведем ссылку на следующую по дате публикации статью, но не из категории 13 (статьи из категории 13 не будут учитываться):
<?php next_post_link('%link', '%title', false, '13'); ?>
#4 Таксономия
Ссылка на следующую запись из текущего термина указанной таксономии. Нужная нам таксономия называется battle_cat
:
next_post_link( '%link', '< %title', true, '', 'battle_cat' );
#5 Зацикленный вывод
Если нужно зациклить вывод, т.е. если нет следующей записи, то вывести первую и наоборот, используйте такой код:
/**
* Зацикленный вывод предыдущего и следующего поста в WordPress
*/
if( get_adjacent_post(false, '', true) ) {
previous_post_link('%link', '← Previous Post');
}
else {
$first = new WP_Query('posts_per_page=1&order=DESC');
$first->the_post();
echo '<a href="' . get_permalink() . '">← Предыдущий пост</a>';
wp_reset_postdata();
};
if( get_adjacent_post(false, '', false) ) {
next_post_link('%link', 'Next Post →');
}
else {
$last = new WP_Query('posts_per_page=1&order=ASC');
$last->the_post();
echo '<a href="' . get_permalink() . '">Следующий пост →</a>';
wp_reset_postdata();
};
Заметки
- Смотрите: get_next_post_link()
Код next post link: wp-includes/link-template.php
WP 5.3
function next_post_link( $format = '%link »', $link = '%title', $in_same_term = false, $excluded_terms = '', $taxonomy = 'category' ) {
echo get_next_post_link( $format, $link, $in_same_term, $excluded_terms, $taxonomy );
}
источник: https://wp-kama.ru/function/next_post_link