Voglio sapere se è possibile ottenere l'ID di una pagina con un modello specifico. È possibile ottenere l'ID di una pagina assegnata a "page-special.php"?
Voglio sapere se è possibile ottenere l'ID di una pagina con un modello specifico. È possibile ottenere l'ID di una pagina assegnata a "page-special.php"?
Risposte:
Quando viene creata una pagina, il modello assegnato a quella pagina viene salvato come meta post personalizzato nello stesso modo dei campi personalizzati. L' meta_key
è _wp_page_template
e meta_value
sarà il modello di pagina
Puoi semplicemente utilizzare get_pages
per recuperare tutte le pagine che hanno un meta_value
modello specificato
$pages = get_pages(array(
'meta_key' => '_wp_page_template',
'meta_value' => 'page-special.php'
));
foreach($pages as $page){
echo $page->ID.'<br />';
}
Se uno ha solo bisogno degli id della pagina, allora usi get_posts
e poi passi il valore page
as post_type
e 'ids as
field`. Ciò garantirà una query molto più veloce, molto più ottimizzata poiché restituiremo solo la colonna ID post nel db e non tutte per le pagine indicate
( Richiede 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 ) se non si desidera interrogare troppo il database.
Se il tuo modello di pagina risiede all'interno di una sottocartella, cartella-tema / modelli-pagina / modello-pagina.php, allora sotto la query funzionerà:
$page_details = get_pages( array(
'post_type' => 'page',
'meta_key' => '_wp_page_template',
'hierarchical' => 0,
'meta_value' => 'page-templates/page-template.php'
));
Questi codici sopra mostrano anche le pagine secondarie.
Grazie
Quello che segue è uno script leggermente più articolato che tiene conto di una lingua, se necessario. NOTA presuppone l'utilizzo di Polylang, non di 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
Ecco una funzione completa che funziona con WPML e Polylang. Ringraziamo 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'];
}
}