get_single_template()WP 1.5.0

Retrieves path of single template in current or parent template. Applies to single Posts, single Attachments, and single custom post types.

The hierarchy for this template looks like:

  1. {Post Type Template}.php
  2. single-{post_type}-{post_name}.php
  3. single-{post_type}.php
  4. single.php

An example of this is:

  1. templates/full-width.php
  2. single-post-hello-world.php
  3. single-post.php
  4. single.php

The template hierarchy and template path are filterable via the {@see '$type_template_hierarchy'} and {@see '$type_template'} dynamic hooks, where $type is 'single'.

Хуков нет.

Возвращает

Строку. Full path to single template file.

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

get_single_template();

Заметки

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

С версии 1.5.0 Введена.
С версии 4.4.0 single-{post_type}-{post_name}.php was added to the top of the template hierarchy.
С версии 4.7.0 The decoded form of single-{post_type}-{post_name}.php was added to the top of the template hierarchy when the post name contains multibyte characters.
С версии 4.7.0 {Post Type Template}.php was added to the top of the template hierarchy.

Код get_single_template() WP 6.5.2

function get_single_template() {
	$object = get_queried_object();

	$templates = array();

	if ( ! empty( $object->post_type ) ) {
		$template = get_page_template_slug( $object );
		if ( $template && 0 === validate_file( $template ) ) {
			$templates[] = $template;
		}

		$name_decoded = urldecode( $object->post_name );
		if ( $name_decoded !== $object->post_name ) {
			$templates[] = "single-{$object->post_type}-{$name_decoded}.php";
		}

		$templates[] = "single-{$object->post_type}-{$object->post_name}.php";
		$templates[] = "single-{$object->post_type}.php";
	}

	$templates[] = 'single.php';

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