get_page_template() WP 1.5.0

Отримує шлях до шаблону сторінки у поточному чи батьківському шаблоні.

Ієрархія для цього шаблону виглядає так:

  1. {шаблон сторінки}.php
  2. page-{page_name}.php
  3. page-{id}.php
  4. page.php

Насправді це виглядає приблизно так:

  1. page-templates/full-width.php
  2. page-about.php
  3. page-4.php
  4. page.php

Дізнайтеся більше про ієрархію теми WordPress .

Ієрархію шаблонів та шлях до шаблону можна змінити за допомогою динамічних фільтрів (type)_template , де $type – це page .

C версії 4.7.0 до ієрархії шаблонів доданий файл page-{$pagename_decoded}.php, де $pagename_decoded = urldecode( page_name ).

Працює на основі:
get_query_template()
1 раз – 0.0007071 сек
(повільно) | 50000 разів – 1.84 сек
(швидко)

Хуків немає.

Повертає

Строку. Повний шлях до файлу шаблону сторінки.

Використання

get_page_template();

Приклади

0

#1 Отримаємо файл шаблону поточної сторінки

echo get_page_template();

// отримаємо: /home/public_html/wp-content/themes/theme-name/page.php

нотатки

список змін

З версії 1.5.0Введено.
З версії 4.7.0Розміщена форма page-{page_name}.php була приєднана до top of the template hierarchy when the page name contains multibyte characters.

Код get_page_template() WP 6.0.2

function get_page_template() {
	$id = get_queried_object_id();
	$template = get_page_template_slug();
	$pagename = get_query_var( 'pagename' );

	if ( ! $pagename && $id ) {
		// If static page is set as the front page, $pagename не буде set.
		// Retrieve it from the queried object.
		$post = get_queried_object();
		if ($post) {
			$pagename = $post->post_name;
		}
	}

	$templates = array();
	if ( $template && 0 === validate_file( $template ) ) {
		$templates[] = $template;
	}
	if ($ pagename) {
		$pagename_decoded = urldecode( $pagename );
		if ( $pagename_decoded !== $pagename ) {
			$templates[] = "page-{$pagename_decoded}.php";
		}
		$templates[] = "page-{$pagename}.php";
	}
	if ($id) {
		$templates[] = "page-{$id}.php";
	}
	$templates[] = 'page.php';

	return get_query_template('page', $templates);
}

Залишити відповідь

Ваша e-mail адреса не оприлюднюватиметься. Обов’язкові поля позначені *