WordPress как на ладони
rgbcode is looking for WordPress developers. Очень Удобный и Быстрый Хостинг для сайтов на WordPress. Пользуюсь сам и вам рекомендую!

comments_popup_link()WP 0.71

Выводит готовую <a> ссылку на всплывающее окно комментариев, работает при использовании скрипта comments_popup_script().

Если нужный скрипт не вызывается, то будет выведена простая ссылка на комментарии записи, см comments_link().

Этот Тег шаблона должен быть внутри Цикла WordPress или цикла комментариев.

Скрипт устарел с версии WP 4.5.0.

Как будет выглядеть всплывающее окно определяется файлом шаблона: comments-popup.php.

Функция ничего не выводит, если отображаются отдельные страницы записей: is_single() или is_page().

1 раз — 0.008033 сек (очень медленно) | 50000 раз — 13.64 сек (медленно) | PHP 7.1.5, WP 4.8.2
Хуки из функции

Возвращает

null.

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

comments_popup_link( $zero, $one, $more, $css_class, $none);
$zero(строка)
Текст для показа, когда нет комментариев.
По умолчанию: 'Нет комментариев'
$one(строка)
Текст для показа, если 1 комментарий.
По умолчанию: '1 комментарий'
$more(строка)
Текст для показа, если более одного комментария.
По умолчанию: '%1$s комментариев'
$css_class(строка)
Название css класса для ссылки. По умолчанию класс не задается.
По умолчанию: ''
$none(строка)
Текст для показа, если у записи комментирование отключено.
По умолчанию: 'Комментирование отключено'

Примеры

0

#1 Вывод ссылки на блок комментариев поста.

<p><?php comments_popup_link(); ?></p>

Получим:

<a href="https://example.com/post-name#respond">No Comments</a>

Если пост защищен паролем (см. post_password_required()), то будет показан текст Введите пароль для просмотра комментариев..

0

#2 Как не показывать ссылку на всплывающее окно комментирования, когда комментарии закрыты:

<?php
if( comments_open() ){
	comments_popup_link( 'Комментариев пока нет', '1 комментарий', '% комментариев', 'с_link' );
}
?>

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

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

Код comments_popup_link() WP 6.6.2

function comments_popup_link( $zero = false, $one = false, $more = false, $css_class = '', $none = false ) {
	$post_id         = get_the_ID();
	$post_title      = get_the_title();
	$comments_number = get_comments_number( $post_id );

	if ( false === $zero ) {
		/* translators: %s: Post title. */
		$zero = sprintf( __( 'No Comments<span class="screen-reader-text"> on %s</span>' ), $post_title );
	}

	if ( false === $one ) {
		/* translators: %s: Post title. */
		$one = sprintf( __( '1 Comment<span class="screen-reader-text"> on %s</span>' ), $post_title );
	}

	if ( false === $more ) {
		/* translators: 1: Number of comments, 2: Post title. */
		$more = _n(
			'%1$s Comment<span class="screen-reader-text"> on %2$s</span>',
			'%1$s Comments<span class="screen-reader-text"> on %2$s</span>',
			$comments_number
		);
		$more = sprintf( $more, number_format_i18n( $comments_number ), $post_title );
	}

	if ( false === $none ) {
		/* translators: %s: Post title. */
		$none = sprintf( __( 'Comments Off<span class="screen-reader-text"> on %s</span>' ), $post_title );
	}

	if ( 0 == $comments_number && ! comments_open() && ! pings_open() ) {
		printf(
			'<span%1$s>%2$s</span>',
			! empty( $css_class ) ? ' class="' . esc_attr( $css_class ) . '"' : '',
			$none
		);
		return;
	}

	if ( post_password_required() ) {
		_e( 'Enter your password to view comments.' );
		return;
	}

	if ( 0 == $comments_number ) {
		$respond_link = get_permalink() . '#respond';
		/**
		 * Filters the respond link when a post has no comments.
		 *
		 * @since 4.4.0
		 *
		 * @param string $respond_link The default response link.
		 * @param int    $post_id      The post ID.
		 */
		$comments_link = apply_filters( 'respond_link', $respond_link, $post_id );
	} else {
		$comments_link = get_comments_link();
	}

	$link_attributes = '';

	/**
	 * Filters the comments link attributes for display.
	 *
	 * @since 2.5.0
	 *
	 * @param string $link_attributes The comments link attributes. Default empty.
	 */
	$link_attributes = apply_filters( 'comments_popup_link_attributes', $link_attributes );

	printf(
		'<a href="%1$s"%2$s%3$s>%4$s</a>',
		esc_url( $comments_link ),
		! empty( $css_class ) ? ' class="' . $css_class . '" ' : '',
		$link_attributes,
		get_comments_number_text( $zero, $one, $more )
	);
}
14 комментариев
Полезные 2 Все
    Войти