Привет. Сегодня мы разберемся как сделать хлебные крошки в WordPress без плагинов. Научим тему выводить их в нужном месте и виде.

Хлебные крошки — это навигационные элементы, которые отображают текущее расположение страницы относительно всего сайта, родительских страниц и т. д. Используется как для навигации пользователей, так и для улучшения индексации поисковыми роботами.

Основную работу будет выполнять функция «custom_breadcrumbs», которую мы опишем чуть ниже. Всё, что нужно будет сделать — вставить эту функцию в файл functions.php вашей темы и вызывать её в нужном месте.

Сама по себе функция просто обрабатывает текущий пост или страницу, определяет есть ли у него родители/категории и выводится полный путь к текущей страницы.

Итак, сама функция «custom_breadcrumbs»:

function custom_breadcrumbs() {
       
    // Settings
    $separator          = '>';
    $breadcrums_id      = 'breadcrumbs';
    $breadcrums_class   = 'breadcrumbs';
    $home_title         = 'Homepage';
      
    // If you have any custom post types with custom taxonomies, put the taxonomy name below (e.g. product_cat)
    $custom_taxonomy    = 'product_cat';
       
    // Get the query & post information
    global $post,$wp_query;
       
    // Do not display on the homepage
    if ( !is_front_page() ) {
       
        // Build the breadcrums
        echo '
      '; // Home page echo '
  '; echo '
  • ' . $separator . '
  '; if ( is_archive() && !is_tax() && !is_category() && !is_tag() ) { echo '
  • ' . post_type_archive_title($prefix, false) . '
  '; } else if ( is_archive() && is_tax() && !is_category() && !is_tag() ) { // If post is a custom post type $post_type = get_post_type(); // If it is a custom post type display name and link if($post_type != 'post') { $post_type_object = get_post_type_object($post_type); $post_type_archive = get_post_type_archive_link($post_type); echo '   '; echo '
  • ' . $separator . '
  '; } $custom_tax_name = get_queried_object()->name; echo '
  • ' . $custom_tax_name . '
  '; } else if ( is_single() ) { // If post is a custom post type $post_type = get_post_type(); // If it is a custom post type display name and link if($post_type != 'post') { $post_type_object = get_post_type_object($post_type); $post_type_archive = get_post_type_archive_link($post_type); echo '   '; echo '
  • ' . $separator . '
  '; } // Get post category info $category = get_the_category(); if(!empty($category)) { // Get last category post is in $last_category = end(array_values($category)); // Get parent any categories and create array $get_cat_parents = rtrim(get_category_parents($last_category->term_id, true, ','),','); $cat_parents = explode(',',$get_cat_parents); // Loop through parent categories and store in variable $cat_display $cat_display = ''; foreach($cat_parents as $parents) { $cat_display .= '
  • '.$parents.'
  '; $cat_display .= '
  • ' . $separator . '
  '; } } // If it's a custom post type within a custom taxonomy $taxonomy_exists = taxonomy_exists($custom_taxonomy); if(empty($last_category) && !empty($custom_taxonomy) && $taxonomy_exists) { $taxonomy_terms = get_the_terms( $post->ID, $custom_taxonomy ); $cat_id = $taxonomy_terms[0]->term_id; $cat_nicename = $taxonomy_terms[0]->slug; $cat_link = get_term_link($taxonomy_terms[0]->term_id, $custom_taxonomy); $cat_name = $taxonomy_terms[0]->name; } // Check if the post is in a category if(!empty($last_category)) { echo $cat_display; echo '
  • ' . get_the_title() . '
  '; // Else if post is in a custom taxonomy } else if(!empty($cat_id)) { echo '   '; echo '
  • ' . $separator . '
  '; echo '
  • ' . get_the_title() . '
  '; } else { echo '
  • ' . get_the_title() . '
  '; } } else if ( is_category() ) { // Category page echo '
  • ' . single_cat_title('', false) . '
  '; } else if ( is_page() ) { // Standard page if( $post->post_parent ){ // If child page, get parents $anc = get_post_ancestors( $post->ID ); // Get parents in the right order $anc = array_reverse($anc); // Parent page loop foreach ( $anc as $ancestor ) { $parents .= '   '; $parents .= '
  • ' . $separator . '
  '; } // Display parent pages echo $parents; // Current page echo '
  • ' . get_the_title() . '
  '; } else { // Just display current page if not parents echo '
  • ' . get_the_title() . '
  '; } } else if ( is_tag() ) { // Tag page // Get tag information $term_id = get_query_var('tag_id'); $taxonomy = 'post_tag'; $args = 'include=' . $term_id; $terms = get_terms( $taxonomy, $args ); $get_term_id = $terms[0]->term_id; $get_term_slug = $terms[0]->slug; $get_term_name = $terms[0]->name; // Display the tag name echo '
  • ' . $get_term_name . '
  '; } elseif ( is_day() ) { // Day archive // Year link echo '   '; echo '
  • ' . $separator . '
  '; // Month link echo '   '; echo '
  • ' . $separator . '
  '; // Day display echo '
  • ' . get_the_time('jS') . ' ' . get_the_time('M') . ' Archives
  '; } else if ( is_month() ) { // Month Archive // Year link echo '   '; echo '
  • ' . $separator . '
  '; // Month display echo '
  • ' . get_the_time('M') . ' Archives
  '; } else if ( is_year() ) { // Display year archive echo '
  • ' . get_the_time('Y') . ' Archives
  '; } else if ( is_author() ) { // Auhor archive // Get the author information global $author; $userdata = get_userdata( $author ); // Display author name echo '
  • ' . 'Author: ' . $userdata->display_name . '
  '; } else if ( get_query_var('paged') ) { // Paginated archives echo '
  • '.__('Page') . ' ' . get_query_var('paged') . '
  '; } else if ( is_search() ) { // Search results page echo '
  • Search results for: ' . get_search_query() . '
  '; } elseif ( is_404() ) { // 404 page echo '
  • ' . 'Error 404' . '
  '; } echo ' '; } }

Готово. Теперь добавим немного CSS для красоты:

#breadcrumbs{
    list-style:none;
    margin:10px 0;
    overflow:hidden;
}
  
#breadcrumbs li{
    display:inline-block;
    vertical-align:middle;
    margin-right:15px;
}
  
#breadcrumbs .separator{
    font-size:18px;
    font-weight:100;
    color:#ccc;
}

Теперь в нужном месте темы (в header.php или single.php, например) нужно вставить вызов этой функции, чтобы в этом месте вывелись хлебные крошки.


Готово. Хлебные крошки в WordPress без плагинов работают.

Если вы турист — вы обязательно должны посетить Питер. А где жить в Питере так, чтобы почувствовать настоящий дух города? В квартире, как и остальные горожане. Поэтому рекомендуем воспользоваться услугой посуточная аренда квартир в Санкт-Петербурге.