W3cubDocs

/WordPress

get_tag_template()

Retrieve path of tag template in current or parent template.

Description

The hierarchy for this template looks like:

  1. tag-{slug}.php
  2. tag-{id}.php
  3. tag.php

An example of this is:

  1. tag-wordpress.php
  2. tag-3.php
  3. tag.php

The template hierarchy and template path are filterable via the ‘$type_template_hierarchy’ and ‘$type_template’ dynamic hooks, where $type is ‘tag’.

See also

Return

(string) Full path to tag template file.

Source

File: wp-includes/template.php

function get_tag_template() {
	$tag = get_queried_object();

	$templates = array();

	if ( ! empty( $tag->slug ) ) {

		$slug_decoded = urldecode( $tag->slug );
		if ( $slug_decoded !== $tag->slug ) {
			$templates[] = "tag-{$slug_decoded}.php";
		}

		$templates[] = "tag-{$tag->slug}.php";
		$templates[] = "tag-{$tag->term_id}.php";
	}
	$templates[] = 'tag.php';

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

Changelog

Version Description
4.7.0 The decoded form of tag-{slug}.php was added to the top of the template hierarchy when the tag slug contains multibyte characters.
2.3.0 Introduced.

© 2003–2019 WordPress Foundation
Licensed under the GNU GPLv2+ License.
https://developer.wordpress.org/reference/functions/get_tag_template