WordPress как на ладони
wordpress jino

get_permalink() WP 1.0.0

Получает постоянную ссылку на запись, для дальнейшего использования в php.

Не выводит ссылку на экран, а возвращает её в переменную.

Может быть использована за пределами Цикла WordPress, для этого нужно указывать первый параметр $id - ID поста, ссылку которого нужно получить.

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

Если не указать параметр ID и использовать эту функция за пределами Цикла WordPress на страницах архивов (категории, архив по дате, архив по авторам и т.д.), функция вернет ссылку на последнюю статью выводимую в Цикле текущей страницы, а не ссылку на текущую страницу.

Работает на основе: get_post_permalink(), get_attachment_link(), get_page_link()
✈ 1 раз = 0.000701с = медленно | 50000 раз = 3.05с = быстро PHP 7.0.8, WP 4.5.3
Хуки из функции:
Возвращает

Строку/false. URL или false, если не удалось получить URL.

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

$url = get_permalink( $post, $leavename );
$post(число/объект)
ID или объект записи (поста), ссылку на который нужно получить.
По умолчанию: ID текущего поста находящегося в Цикле WordPress (the loop)
$leavename(логический)
Не заменять имя поста в ссылке, т.е. не заменять тег %postname% на имя поста.
По умолчанию: false

Примеры

#1 Получим ссылку на текущую запись

Получить ссылку на пост (внутри Цикла WordPress). Так как функция не выводит данные, то нужно использовать php команду echo :

Постоянная ссылка на пост:<br />
<?php echo get_permalink(); ?>

#2 Получаем ссылки на определенные посты

Выведем список, в котором получим ссылки на страницы с ID 1 и 10.

Информация о блоге:
<ul>
	<li><a href="<?php echo get_permalink(1); ?>">О блоге</a></li>
	<li><a href="<?php echo get_permalink(10); ?>">Об авторе</a></li>
</ul>

#3 Использование со вторым параметром

Оставляем тег %postname% неизменным, например у нас в ЧПУ стоит структура %post_id%/%postname%, тогда функция сработает так:

<?php echo get_permalink(185, true ); ?>

// выведет: http://site.ru/185/%postname%

Код get permalink: wp-includes/link-template.php WP 4.9

<?php
function get_permalink( $post = 0, $leavename = false ) {
	$rewritecode = array(
		'%year%',
		'%monthnum%',
		'%day%',
		'%hour%',
		'%minute%',
		'%second%',
		$leavename? '' : '%postname%',
		'%post_id%',
		'%category%',
		'%author%',
		$leavename? '' : '%pagename%',
	);

	if ( is_object( $post ) && isset( $post->filter ) && 'sample' == $post->filter ) {
		$sample = true;
	} else {
		$post = get_post( $post );
		$sample = false;
	}

	if ( empty($post->ID) )
		return false;

	if ( $post->post_type == 'page' )
		return get_page_link($post, $leavename, $sample);
	elseif ( $post->post_type == 'attachment' )
		return get_attachment_link( $post, $leavename );
	elseif ( in_array($post->post_type, get_post_types( array('_builtin' => false) ) ) )
		return get_post_permalink($post, $leavename, $sample);

	$permalink = get_option('permalink_structure');

	/**
	 * Filters the permalink structure for a post before token replacement occurs.
	 *
	 * Only applies to posts with post_type of 'post'.
	 *
	 * @since 3.0.0
	 *
	 * @param string  $permalink The site's permalink structure.
	 * @param WP_Post $post      The post in question.
	 * @param bool    $leavename Whether to keep the post name.
	 */
	$permalink = apply_filters( 'pre_post_link', $permalink, $post, $leavename );

	if ( '' != $permalink && !in_array( $post->post_status, array( 'draft', 'pending', 'auto-draft', 'future' ) ) ) {
		$unixtime = strtotime($post->post_date);

		$category = '';
		if ( strpos($permalink, '%category%') !== false ) {
			$cats = get_the_category($post->ID);
			if ( $cats ) {
				$cats = wp_list_sort( $cats, array(
					'term_id' => 'ASC',
				) );

				/**
				 * Filters the category that gets used in the %category% permalink token.
				 *
				 * @since 3.5.0
				 *
				 * @param WP_Term  $cat  The category to use in the permalink.
				 * @param array    $cats Array of all categories (WP_Term objects) associated with the post.
				 * @param WP_Post  $post The post in question.
				 */
				$category_object = apply_filters( 'post_link_category', $cats[0], $cats, $post );

				$category_object = get_term( $category_object, 'category' );
				$category = $category_object->slug;
				if ( $parent = $category_object->parent )
					$category = get_category_parents($parent, false, '/', true) . $category;
			}
			// show default category in permalinks, without
			// having to assign it explicitly
			if ( empty($category) ) {
				$default_category = get_term( get_option( 'default_category' ), 'category' );
				if ( $default_category && ! is_wp_error( $default_category ) ) {
					$category = $default_category->slug;
				}
			}
		}

		$author = '';
		if ( strpos($permalink, '%author%') !== false ) {
			$authordata = get_userdata($post->post_author);
			$author = $authordata->user_nicename;
		}

		$date = explode(" ",date('Y m d H i s', $unixtime));
		$rewritereplace =
		array(
			$date[0],
			$date[1],
			$date[2],
			$date[3],
			$date[4],
			$date[5],
			$post->post_name,
			$post->ID,
			$category,
			$author,
			$post->post_name,
		);
		$permalink = home_url( str_replace($rewritecode, $rewritereplace, $permalink) );
		$permalink = user_trailingslashit($permalink, 'single');
	} else { // if they're not using the fancy permalink option
		$permalink = home_url('?p=' . $post->ID);
	}

	/**
	 * Filters the permalink for a post.
	 *
	 * Only applies to posts with post_type of 'post'.
	 *
	 * @since 1.5.0
	 *
	 * @param string  $permalink The post's permalink.
	 * @param WP_Post $post      The post in question.
	 * @param bool    $leavename Whether to keep the post name.
	 */
	return apply_filters( 'post_link', $permalink, $post, $leavename );
}

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

Из метки: permalink (постоянные ссылки ЧПУ)

Еще из раздела: Записи: посты, страницы, ...

get_permalink 51 комментарий
Полезные 1 Вопросы 2 Все
  • Саня cайт: zakonipravo.hav.by

    Добрый день! Подскажите, может есть общая функция, которая бы выводила постоянную ссылку на запись, или на страницу, или на категорию. то есть, как get_permalink() для записи, но только общая для всех видов.

    Ответить1.5 года назад #
    • Kama4558

      Такой нет: их 2 get_permalink() - для записей get_term_link() для элементов таксономий. Больше в вордпресс никаких типов данных по умолчанию нет...

      1
      Ответить1.5 года назад #
  • Alexey @

    Тимур, а что посоветуешь использовать, чтобы надежно получать адрес любой текущей страницы в любом месте блога? Нужно, чтобы сделать ссылку "Войти" и обратный редирект в то место, где эту ссылку нажали.

  • Виталий

    Подскажите, ссылки выводятся со сдвигом на одну новость

    <?php $text = new WP_Query('category_name=text&posts_per_page=3&ignore_sticky_posts=true'); ?>
    <?php while ($text ->have_posts()) { ?>
    <?php if ($text ->have_posts()): ?>
    <a href="<?php echo esc_url(get_permalink());?>">
    *блок с заголовком и миниатюрой*
    </a>
    <?php endif; ?>

    Заголовок и миниатюра выводятся правильно, а вот первая ссылка ведет на запись из другой категории. Ссылка второй записи ведет на предыдущую запись

    Ответить4 месяца назад #
  • campusboy1894 cайт: www.youtube.com/c/wpplus

    Так же работает на основе get_attachment_link() и get_page_link() минимум, если судить по коду.

    Ответить2 месяца назад #

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

Ваш комментарий