Quiero saber si es posible obtener la ID de una página con una plantilla específica. ¿Es posible obtener el ID de una página que se asignó a "page-special.php"?
Quiero saber si es posible obtener la ID de una página con una plantilla específica. ¿Es posible obtener el ID de una página que se asignó a "page-special.php"?
Respuestas:
Cuando se crea una página, la plantilla asignada a esa página se guarda como metaetiquetado personalizado de la misma manera que los campos personalizados. El meta_key
es _wp_page_template
y meta_value
será la plantilla de página
Simplemente puede utilizar get_pages
para recuperar todas las páginas que tienen una meta_value
de las plantillas especificadas
$pages = get_pages(array(
'meta_key' => '_wp_page_template',
'meta_value' => 'page-special.php'
));
foreach($pages as $page){
echo $page->ID.'<br />';
}
Si uno solo necesita los identificadores de página, entonces utiliza get_posts
y luego pasa page
como valor de post_type
' as
campos de identificadores' . Esto garantizará una consulta mucho más rápida y mucho más optimizada, ya que solo devolveremos la columna de ID de publicación en el DB y no todas para las páginas dadas
( Requiere PHP 5.4+ )
$args = [
'post_type' => 'page',
'fields' => 'ids',
'nopaging' => true,
'meta_key' => '_wp_page_template',
'meta_value' => 'page-special.php'
];
$pages = get_posts( $args );
foreach ( $pages as $page )
echo $page . '</br>';
set_transient
( codex.wordpress.org/Transients_API ) si no desea consultar demasiado la base de datos.
Si la plantilla de su página reside dentro de la subcarpeta, theme-folder / page-templates / page-template.php, la siguiente consulta funcionará:
$page_details = get_pages( array(
'post_type' => 'page',
'meta_key' => '_wp_page_template',
'hierarchical' => 0,
'meta_value' => 'page-templates/page-template.php'
));
Estos códigos anteriores también muestran subpáginas también.
Gracias
El siguiente es un script ligeramente más articulado que tiene en cuenta un idioma, si es necesario. NOTA que asume el uso de Polylang, no WPML.
function get_post_id_by_template($template,$lang_slug = null){
global $wpdb;
$wh = ($lang_slug) ? " AND t.slug = %s" : "";
$query = $wpdb->prepare(
"SELECT DISTINCT p.ID
FROM $wpdb->posts p
INNER JOIN $wpdb->postmeta meta ON meta.post_id = p.ID
INNER JOIN $wpdb->term_relationships tr ON meta.post_id = tr.object_id
INNER JOIN $wpdb->term_taxonomy tt ON tr.term_taxonomy_id = tt.term_taxonomy_id
INNER JOIN $wpdb->terms t ON tt.term_id = t.term_id
WHERE p.post_status = 'publish' AND meta.meta_key = %s AND meta.meta_value = %s" . $wh,
'_wp_page_template',
$template,
$lang_slug
);
$ids = $wpdb->get_results($query);
if($ids && isset($ids[0])){
$p = $ids[0];
return $p->ID;
} else {
return false;
}
}// get_post_id_by_template
Aquí hay una función completa que funciona con WPML y Polylang. Crédito a https://github.com/cyrale/
/**
* Search for a page with a particular template.
*
* @param string $template Template filename.
* @param array $args (Optional) See also get_posts() for example parameter usage.
* @param bool $single (Optional) Whether to return a single value.
*
* @return Will be an array of WP_Post if $single is false. Will be a WP_Post object if the page is find, FALSE otherwise
*/
if (!function_exists('get_page_by_template')) {
function get_page_by_template($template, $args = array(), $single = true) {
$pages_by_template = wp_cache_get('pages_by_template', 'cyrale');
if (empty($pages_by_template) || !is_array($pages_by_template)) {
$pages_by_template = array();
}
if (!isset($pages_by_template[$template])) {
$args = wp_parse_args(array(
'posts_per_page' => -1,
'post_type' => 'page',
'suppress_filters' => 0,
'meta_query' => array(
array(
'key' => '_wp_page_template',
'value' => $template,
),
),
), $args);
$pages = get_posts($args);
$pages_by_template[$template]= array(
'single' => !empty($pages) && is_array($pages) ? reset($pages) : false,
'pages' => $pages,
);
}
wp_cache_set('pages_by_template', $pages_by_template, 'cyrale');
return $pages_by_template[$template][$single ? 'single' : 'pages'];
}
}