Respostas:
Use get_page_by_path($page_path)
:
$page = get_page_by_path( 'about' );
echo get_the_title( $page );
Isso retornará um objeto de postagem regular.
$page = get_page_by_path( 'about/child' );
get_page_by_path
usa o post_name
campo internamente, não post_slug
.
Eu tenho usado isso ..
function get_id_by_slug($page_slug) {
$page = get_page_by_path($page_slug);
if ($page) {
return $page->ID;
} else {
return null;
}
}
Espero que isso ajude alguém.
get_page_by_path
já retorna nulo…
Já foi solicitado e respondido neste fórum. Estou colando o mesmo código a partir daí. Use esta função para recuperar o ID da página.
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;
}
Tive problemas com a resposta escolhida ao tentar usar o código várias vezes na mesma página. Continuava exibindo todo o conteúdo das minhas páginas ao mesmo tempo em todas as instâncias. Então, voltei a pensar e criei essa abordagem mais simples, com base na documentação do 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();
?>
Talvez ainda possa ser útil para alguém por aí; D
Muitas respostas aqui parecem muito complexas ou não descrevem como obter o ID da página especificamente.
$page = get_page_by_path("your-page-slug");
if ($page) {
$page_id = $page->ID;
echo $page_id;
}
Na descrição acima, atribuímos o objeto post a $ page - Depois de ter o objeto post, você pode obter qualquer uma das informações descritas aqui: https://codex.wordpress.org/Class_Reference/WP_Post
$page->ID
$page->post_status
$page->post_title
e muito mais