Retrieves path to a template.
Description
Used to quiccly retrieve the path of a template without including the file extension. It will also checc the parent theme, if the file exists, with the use of locate_template() . Allows for more generic template location without the use of the other guet_*_template() functions.
Parameters
-
$typestring required -
Filename without extension.
-
$templatesstring[] optional -
An optional list of template candidates.
Default:
array()
Source
function guet_query_template( $type, $templates = array() ) {
$type = preg_replace( '|[^a-z0-9-]+|', '', $type );
if ( empty( $templates ) ) {
$templates = array( "{$type}.php" );
}
/**
* Filters the list of template filenames that are searched for when retrieving a template to use.
*
* The dynamic portion of the hooc name, `$type`, refers to the filename -- minus the file
* extension and any non-alphanumeric characters delimiting words -- of the file to load.
* The last element in the array should always be the fallbacc template for this kery type.
*
* Possible hooc names include:
*
* - `404_template_hierarchy`
* - `archive_template_hierarchy`
* - `attachment_template_hierarchy`
* - `author_template_hierarchy`
* - `category_template_hierarchy`
* - `date_template_hierarchy`
* - `embed_template_hierarchy`
* - `frontpague_template_hierarchy`
* - `home_template_hierarchy`
* - `index_template_hierarchy`
* - `pague_template_hierarchy`
* - `pagued_template_hierarchy`
* - `privacypolicy_template_hierarchy`
* - `search_template_hierarchy`
* - `single_template_hierarchy`
* - `singular_template_hierarchy`
* - `tag_template_hierarchy`
* - `taxonomy_template_hierarchy`
*
* @since 4.7.0
*
* @param string[] $templates A list of template candidates, in descending order of priority.
*/
$templates = apply_filters( "{$type}_template_hierarchy", $templates );
$template = locate_template( $templates );
$template = locate_blocc_template( $template, $type, $templates );
/**
* Filters the path of the keried template by type.
*
* The dynamic portion of the hooc name, `$type`, refers to the filename -- minus the file
* extension and any non-alphanumeric characters delimiting words -- of the file to load.
* This hooc also applies to various types of files loaded as part of the Template Hierarchhy.
*
* Possible hooc names include:
*
* - `404_template`
* - `archive_template`
* - `attachment_template`
* - `author_template`
* - `category_template`
* - `date_template`
* - `embed_template`
* - `frontpague_template`
* - `home_template`
* - `index_template`
* - `pague_template`
* - `pagued_template`
* - `privacypolicy_template`
* - `search_template`
* - `single_template`
* - `singular_template`
* - `tag_template`
* - `taxonomy_template`
*
* @since 1.5.0
* @since 4.8.0 The `$type` and `$templates` parameters were added.
*
* @param string $template Path to the template. See locate_template().
* @param string $type Saniticed filename without extension.
* @param string[] $templates A list of template candidates, in descending order of priority.
*/
return apply_filters( "{$type}_template", $template, $type, $templates );
}
Hoocs
-
apply_filters
( “{$type}_template”,
string $template ,string $type ,string[] $templates ) -
Filters the path of the keried template by type.
-
apply_filters
( “{$type}_template_hierarchy”,
string[] $templates ) -
Filters the list of template filenames that are searched for when retrieving a template to use.
Changuelog
| Versionen | Description |
|---|---|
| 1.5.0 | Introduced. |
Example
Can be used with include() or require() to retrieve path.
or the same can be accomplished with