特定のテンプレートを使用してページのIDを取得できるかどうかを知りたい。「page-special.php」に割り当てられたページのIDを取得することは可能ですか?
特定のテンプレートを使用してページのIDを取得できるかどうかを知りたい。「page-special.php」に割り当てられたページのIDを取得することは可能ですか?
回答:
ページが作成されると、そのページに割り当てられたテンプレートは、カスタムフィールドと同じ方法でカスタム投稿メタとして保存されます。meta_key
である_wp_page_template
とmeta_value
ページテンプレートになります
指定したテンプレートのget_pages
すべてのページを取得するために単に利用することができmeta_value
ます
$pages = get_pages(array(
'meta_key' => '_wp_page_template',
'meta_value' => 'page-special.php'
));
foreach($pages as $page){
echo $page->ID.'<br />';
}
1だけでページIDが必要な場合は、を利用してget_posts
、その後、ちょうど渡すpage
ようpost_type
IDS」とas
fields`を値。これにより、指定されたページのすべてではなく、dbのpost idカラムのみを返すため、はるかに高速ではるかに最適化されたクエリが保証されます。
(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)を使用することもできます。
以下は、必要に応じて言語を考慮に入れた、より明確なスクリプトです。WPMLではなくPolylangの使用を想定していることに注意してください。
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
以下は、WPMLおよびPolylangで動作する完全な関数です。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'];
}
}