Ответы:
Используйте get_page_by_path($page_path)
:
$page = get_page_by_path( 'about' );
echo get_the_title( $page );
Это вернет обычный объект post.
$page = get_page_by_path( 'about/child' );
get_page_by_path
использует это post_name
поле внутри, а не post_slug
.
Я использовал это ..
function get_id_by_slug($page_slug) {
$page = get_page_by_path($page_slug);
if ($page) {
return $page->ID;
} else {
return null;
}
}
Надеюсь, это кому-нибудь поможет.
get_page_by_path
уже возвращает
Об этом уже спрашивали и отвечали на этом форуме. Я вставляю тот же код оттуда. Используйте эту функцию для получения идентификатора страницы.
function get_page_by_slug($page_slug, $output = OBJECT, $post_type = 'page' ) {
global $wpdb;
$page = $wpdb->get_var( $wpdb->prepare( "SELECT ID FROM $wpdb->posts WHERE post_name = %s AND post_type= %s AND post_status = 'publish'", $page_slug, $post_type ) );
if ( $page )
return get_post($page, $output);
return null;
}
У меня были проблемы с выбранным ответом при попытке использовать код несколько раз на одной странице. Он продолжал отображать все содержимое моих страниц одновременно в каждом случае. Поэтому я вернулся к размышлениям и предложил этот более простой подход, основанный на документации WordPress Codex :
<?php $query = new WP_Query( array( 'pagename' => 'about-me' ) );
while ( $query->have_posts() ) {
$query->the_post();
echo '<h2>'. get_the_title() .'</h2>';
the_content();
}
wp_reset_postdata();
?>
Может быть, это все еще может быть полезным для кого-то там; D
Здесь много ответов, которые кажутся слишком сложными или не описывают, как получить идентификатор страницы конкретно.
$page = get_page_by_path("your-page-slug");
if ($page) {
$page_id = $page->ID;
echo $page_id;
}
В вышеприведенном описании мы назначили объект post для $ page. Получив объект post, вы можете получить любую информацию, описанную здесь: https://codex.wordpress.org/Class_Reference/WP_Post.
$page->ID
$page->post_status
$page->post_title
и многое другое