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

the_meta()WP 1.2.0

Устарела с версии 6.0.2. Больше не поддерживается и может быть удалена. Используйте get_post_meta() to retrieve post meta and render manually.

Выводит произвольные поля записи (метаданные из wp_postmeta). Поля выводятся в списке <li>. Скрытые поля игнорируются.

Функция должна использоваться внутри Цикла WordPress или в файле single.php - там где есть данные записи.

Скрытые поля — произвольные поля (названия полей) начинающиеся с нижнего подчеркивания _ игнорируются (в списке не попадают). Такая маркировка используются WordPress для системных метаполей.

Работает на основе: get_post_custom_keys()
1 раз — 0.001464 сек (очень медленно) | 50000 раз — 2.87 сек (быстро) | PHP 7.1.2, WP 4.7.3
Хуки из функции

Возвращает

null.

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

<?php the_meta(); ?>

Примеры

0

#1 Выведем метаданные поста

Для этого разместим следующий код в файле single.php после тега шаблона (функции) the_content():

<p>Мета информация о текущем посте:</p>
<?php the_meta(); ?>

Этот код выведет следующие

<p>Мета информация о текущем посте:</p>
<ul class='post-meta'>
	<li><span class='post-meta-key'>название ключа:</span> значение поля</li>
</ul>

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

С версии 1.2.0 Введена.
Устарела с 6.0.2 Use get_post_meta() to retrieve post meta and render manually.

Код the_meta() WP 6.5.2

function the_meta() {
	_deprecated_function( __FUNCTION__, '6.0.2', 'get_post_meta()' );
	$keys = get_post_custom_keys();
	if ( $keys ) {
		$li_html = '';
		foreach ( (array) $keys as $key ) {
			$keyt = trim( $key );
			if ( is_protected_meta( $keyt, 'post' ) ) {
				continue;
			}

			$values = array_map( 'trim', get_post_custom_values( $key ) );
			$value  = implode( ', ', $values );

			$html = sprintf(
				"<li><span class='post-meta-key'>%s</span> %s</li>\n",
				/* translators: %s: Post custom field name. */
				esc_html( sprintf( _x( '%s:', 'Post custom field name' ), $key ) ),
				esc_html( $value )
			);

			/**
			 * Filters the HTML output of the li element in the post custom fields list.
			 *
			 * @since 2.2.0
			 *
			 * @param string $html  The HTML output for the li element.
			 * @param string $key   Meta key.
			 * @param string $value Meta value.
			 */
			$li_html .= apply_filters( 'the_meta_key', $html, $key, $value );
		}

		if ( $li_html ) {
			echo "<ul class='post-meta'>\n{$li_html}</ul>\n";
		}
	}
}
8 комментариев
    Войти