Odpowiedzi:
Użyj get_page_by_path($page_path)
:
$page = get_page_by_path( 'about' );
echo get_the_title( $page );
Zwróci to zwykły obiekt postu.
$page = get_page_by_path( 'about/child' );
get_page_by_path
używa post_name
pola wewnętrznie, a nie post_slug
.
Korzystałem z tego ..
function get_id_by_slug($page_slug) {
$page = get_page_by_path($page_slug);
if ($page) {
return $page->ID;
} else {
return null;
}
}
Mam nadzieję, że to komuś pomoże.
get_page_by_path
zwraca już zero…
To pytanie zostało już zadane i udzielono odpowiedzi na tym forum. Wklejam stamtąd ten sam kod. Użyj tej funkcji, aby pobrać identyfikator strony.
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;
}
Miałem problemy z wybraną odpowiedzią, gdy próbowałem użyć kodu kilka razy na tej samej stronie. Za każdym razem wyświetlał wszystkie moje strony w tym samym czasie. Więc wróciłem do myślenia i wymyśliłem to prostsze podejście oparte na dokumentacji Kodeksu WordPress :
<?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();
?>
Może nadal może być pomocny dla kogoś tam; D
Wiele odpowiedzi tutaj wydaje się zbyt skomplikowanych lub nie opisuje, w jaki sposób uzyskać konkretny identyfikator strony.
$page = get_page_by_path("your-page-slug");
if ($page) {
$page_id = $page->ID;
echo $page_id;
}
W powyższym opisie przypisaliśmy obiekt postu do strony $ - Gdy już masz obiekt posta, możesz uzyskać dowolne informacje opisane tutaj: https://codex.wordpress.org/Class_Reference/WP_Post
$page->ID
$page->post_status
$page->post_title
i dużo więcej