Trusted WordPress tutorials, when you need them most.
Beginner’s Guide to WordPress
WPB Kupası
25 Million+
Websites using our plugins
16+
Years of WordPress experience
3000+
WordPress tutorials
by experts

WordPress Temalarınıza Menü Açıklamaları Nasıl Eklenir?

WordPress menü sistemi, menü öğelerine açıklama ekleyebileceğiniz yerleşik bir özelliğe sahiptir. Ancak bu özellik varsayılan olarak gizlidir. Etkinleştirildiğinde bile, bazı kodlar eklenmeden bunların görüntülenmesi desteklenmez. Çoğu tema menü öğesi açıklamaları düşünülerek tasarlanmamıştır. Bu makalede WordPress’te menü açıklamalarını nasıl etkinleştireceğinizi ve WordPress temalarınıza menü açıklamalarını nasıl ekleyeceğinizi göstereceğiz.

How to add menu descriptions in WordPress themes

Not: Bu eğitim HTML, CSS ve WordPress tema geliştirme konularında yeterli bilgiye sahip olmanızı gerektirmektedir.

Menü Açıklamalarını Ne Zaman ve Neden Eklemek İstersiniz?

Bazı kullanıcılar menü açıklaması eklemenin SEO’ya yardımcı olacağını düşünüyor. Ancak, bunları kullanmak istemenizin ana nedeninin sitenizde daha iyi bir kullanıcı deneyimi sunmak olduğunu düşünüyoruz.

Açıklamalar, ziyaretçilere bir menü öğesine tıkladıklarında ne bulacaklarını anlatmak için kullanılabilir. İlgi çekici bir açıklama, daha fazla kullanıcının menülere tıklamasını sağlayacaktır.

Menu Descriptions

Adım 1: Menü Açıklamalarını Açın

Görünüm ” Menüler bölümüne gidin. Sayfanın sağ üst köşesindeki Ekran Seçenekleri düğmesine tıklayın. Açıklamalar kutusunu işaretleyin.

Enabling menu descriptions in WordPress

Bu, menü öğelerinizde açıklamalar alanını etkinleştirecektir. Bunun gibi:

Description field added to menu items

Artık WordPress menünüzdeki öğelere menü açıklamaları ekleyebilirsiniz. Ancak bu açıklamalar henüz temalarınızda görünmeyecektir. Menü açıklamalarını görüntülemek için bazı kodlar eklememiz gerekecek.

Adım 2: Yürüteç sınıfını ekleyin:

Walker sınıfı WordPress’teki mevcut sınıfı genişletir. Temel olarak menü öğesi açıklamalarını görüntülemek için sadece bir kod satırı ekler. Bu kodu temanızın functions.php dosyasına ekleyin.

class Menu_With_Description extends Walker_Nav_Menu {
	function start_el(&$output, $item, $depth, $args) {
		global $wp_query;
		$indent = ( $depth ) ? str_repeat( "\t", $depth ) : '';
		
		$class_names = $value = '';

		$classes = empty( $item->classes ) ? array() : (array) $item->classes;

		$class_names = join( ' ', apply_filters( 'nav_menu_css_class', array_filter( $classes ), $item ) );
		$class_names = ' class="' . esc_attr( $class_names ) . '"';

		$output .= $indent . '<li id="menu-item-'. $item->ID . '"' . $value . $class_names .'>';

		$attributes = ! empty( $item->attr_title ) ? ' title="' . esc_attr( $item->attr_title ) .'"' : '';
		$attributes .= ! empty( $item->target ) ? ' target="' . esc_attr( $item->target ) .'"' : '';
		$attributes .= ! empty( $item->xfn ) ? ' rel="' . esc_attr( $item->xfn ) .'"' : '';
		$attributes .= ! empty( $item->url ) ? ' href="' . esc_attr( $item->url ) .'"' : '';

		$item_output = $args->before;
		$item_output .= '<a'. $attributes .'>';
		$item_output .= $args->link_before . apply_filters( 'the_title', $item->title, $item->ID ) . $args->link_after;
		$item_output .= '<br /><span class="sub">' . $item->description . '</span>';
		$item_output .= '</a>';
		$item_output .= $args->after;

		$output .= apply_filters( 'walker_nav_menu_start_el', $item_output, $item, $depth, $args );
	}
}

Adım 3. wp_nav_menu’de Yürüteci Etkinleştir

WordPress temaları menüleri görüntülemek için wp_nav_menu() fonksiyonunu kullanır. WordPress Temalarında özel navigasyon menülerinin nasıl ekleneceği hakkında yeni başlayanlar için bir eğitim de yayınladık. Çoğu WordPress teması menüleri header.php şablonuna ekler. Ancak, temanız menüleri görüntülemek için başka bir şablon dosyası kullanmış olabilir.

Şimdi yapmamız gereken temanızdaki wp_nav_menu() fonksiyonunu bulmak (büyük olasılıkla header.php’de) ve şu şekilde değiştirmek.


<?php $walker = new Menu_With_Description; ?>

<?php wp_nav_menu( array( 'theme_location' => 'primary', 'menu_class' => 'nav-menu', 'walker' => $walker ) ); ?>

İlk satırda $walker ‘ı daha önce functions.php‘de tanımladığımız walker sınıfını kullanacak şekilde ayarlıyoruz. İkinci kod satırında, mevcut wp_nav_menu argümanlarımıza eklememiz gereken tek ekstra argüman 'walker' => $walker.

4. Adım Açıklamaları Şekillendirme

Daha önce eklediğimiz walker sınıfı, bu kod satırında öğe açıklamalarını görüntüler:

$item_output .= '<br /><span class="sub">' . $item->description . '</span>';

Yukarıdaki kod, menü öğesine bir satır sonu ekleyerek
etiketini kullanır ve ardından açıklamalarınızı sub sınıfı ile bir span içine sarar. Bunun gibi:

<li id="menu-item-99" class="menu-item menu-item-type-post_type menu-item-object-page"><a href="http://www.example.com/about/">Hakkında<br /><span class="sub">Biz Kimiz? </span></a></li>

Açıklamalarınızın sitenizde nasıl görüneceğini değiştirmek için temanızın stil sayfasına CSS ekleyebilirsiniz. Bunu Twenty Twelve üzerinde test ediyorduk ve bu css’yi kullandık.

.menu-item {
border-left: 1px solid #ccc;
}

span.sub { 
font-style:italic;
font-size:small;
}

Bu makaleyi faydalı bulacağınızı ve temanızda menü açıklamaları ile havalı görünen menüler oluşturmanıza yardımcı olacağını umuyoruz. Sorularınız mı var? Aşağıdaki yorumlarda bırakın.

Ek Kaynaklar

WordPress Navigasyon Menüleri Nasıl Şekillendirilir?

Belirli WordPress Menülerine Özel Öğeler Ekleme

Bill Erickson’ın Açıklamalı Menüler Sınıfı

Açıklama: İçeriğimiz okuyucu desteklidir. Bu, bazı bağlantılarımıza tıklarsanız komisyon kazanabileceğimiz anlamına gelir. WPBeginner'ın nasıl finanse edildiğini, neden önemli olduğunu ve nasıl destek olabileceğinizi görün. İşte editoryal sürecimiz.

Avatar

Editorial Staff at WPBeginner is a team of WordPress experts led by Syed Balkhi with over 16 years of experience in WordPress, Web Hosting, eCommerce, SEO, and Marketing. Started in 2009, WPBeginner is now the largest free WordPress resource site in the industry and is often referred to as the Wikipedia for WordPress.

Ultimate WordPress Araç Kiti

Araç setimize ÜCRETSİZ erişim sağlayın - her profesyonelin sahip olması gereken WordPress ile ilgili ürün ve kaynaklardan oluşan bir koleksiyon!

Reader Interactions

51 yorumBir Cevap Bırakın

  1. Matthew Blaxton

    In PHP 8.0 and higher this with throw a critical error.

    You need to find this line:
    function start_el( $output, $item, $depth, $args ) {

    Changing that line to the following should make the error disappear:
    function start_el( &$output, $item, $depth = 0, $args = array(), $id = 0 ) {

    • WPBeginner Support

      Thank you for sharing that for those on PHP 8.

      Yönetici

  2. Norman

    Hi,
    How can you make the description clickable too?

    • WPBeginner Support

      We cover that in step 4 :)

      Yönetici

  3. kayvan A.Gilani

    To Add Menu Descriptions in My WordPress Themes, I did step 1 and 2 of this blog but couldn’t follow in step 3 to move forward and perform the total change.

    • WPBeginner Support

      If you cannot find the function in your theme, we would recommend reaching out to your specific theme’s support and they should be able to assist.

      Yönetici

  4. yiannis

    Hi,
    How to disable product category description in max mega menu ?
    I have already gone to Mega Menu > General Settings and set Menu Item Descriptions to disabled but the problem exists.

    • WPBeginner Support

      You would want to reach out to the plugin’s support and they would be able to assist with the setting not working correctly

      Yönetici

    • WPBeginner Support

      You’re welcome :)

      Yönetici

  5. Lanka

    Thank you so much, you saved me

  6. dan

    Can this work with the WP_Bootstrap_Navwalker ?

    as i’ve tried it and it breaks my site….

  7. kalpana

    Thank you so much….was very useful to me….you saved my day

  8. Steven

    how to turn off the description in mobile layout?

  9. Anzani Zahrani

    Hello.. Please Help..
    How to add title category, not using title category description ?

  10. Ido Schacham

    Totally helpful, thanks!

  11. Rahman

    Great Tip but in menu description it does not support html tags. can anyone know about this?

    Thanks

  12. Iryna

    Hi Guys,

    Any ideas how to allow html tags in the description?
    remove_filter(‘nav_menu_description’, ‘strip_tags’);
    this one not work for me.

    • Damien Carbery

      @Iryna: Can you post your code somewhere e.g. pastebin.com.
      Where you call remove_filter() will determine whether it works – it has to be called after the add_filter() call.
      Calling it just before the wp_nav_menu() call might work.

  13. Max

    Is there anyway for the description not to be hyperlinked?

  14. Ashok

    thanks…it worked. but in menu description it does not support html tags.

  15. igorasas

    May already be there ready to plug-in? How this hack will work with the theme of “Twenty TwelveVersion: 1.5”
    ? And just as with the plugin wpml?

  16. Phong

    Thank you, this was really helpful to just copy paste this and get the quick picture.

  17. Chad

    Hey man, I added the walker class to functions.php, but I cannot find the wp_nav_menu in genesis theme. What am I missing? I have no idea what to do next?!?!

  18. Ksenia

    You expain very well – detailed and clearly. 1 minute and menu items descriptions are ok. Thank you!

  19. Mary Anne

    Thank you so much for this tutorial. It was recommended to me and it worked perfectly for making the changes I wanted to make. However, in making these changes, I’ve lost my drop down sub-item menus. Any idea what affected that in the code change?

    Thank you for your time and tutorial

    • WPBeginner Support

      It seems like a CSS issue, we are sorry we couldn’t be more specific. Try using Google Chrome’s developer tools to debug it.

      Yönetici

  20. Paul Renault

    I have implemented the menu descriptions and it worked great. Now my client is asking for a line break within one of the descriptions. I have tried putting a carriage return and inserting a tag into the description field through the admin. It doesn’t appear in the front end. WP removes these edits. Is there a way to remedy this?

      • Paul Renault

        The client wants a line break. Is there a way that I can insert a tag in the description? If I put one in now it gets removed.

  21. Barry

    Great tutorial guys, just want to know how to implement this on a custom menu displayed using the Custom Menu widget?

  22. Oryan Consulting

    Thank you! Been working on WordPress for years and I’ve never even heard of this before. I was looking to remove the descriptions as they were very redundant on the site I’m working on. I looked everywhere for where they were coming from.

    Oh joy!

  23. sambassador

    works!

    but for php 5.4 you’ll have to match the wp walker arguments for the start_el function:

    function start_el( &$output, $object, $depth = 0, $args = array(), $current_object_id = 0 )

    and find replace $item with $object.

  24. Steve Covello

    You Rock!! Worked perfectly.

  25. Kevin Gilbert

    Perfect. This was just what I needed to finish up on a site. I had some issues with the CSS, but I finally figured it out and got it working. Thanks for the great articles.

  26. Jon

    Excellent tip. Worked perfectly!

  27. Jedediah White

    This worked perfectly for me. The class function is perfect too. Thanks a lot!

  28. Pankaj

    I needed to create same thing and I was totally lost.

    I was planning to do some stupid things to get this thing done.

    thank god I found this post and saved time and stress!

    I simply love this site got to know so much things.

    Thanks you so much for showing the easiest things here.

    • Pankaj

      The span tag is coming on sub-menus too.

      its not showing there but it is taking that much of space which makes it look too odd.

      is there any workaround for the same??

  29. DiTesco

    This is really a great tutorial and I was wondering if this would work on the Thesis 1.8.5? If not, it would be great if you can provide one. I will most certainly help you put it out there. Thumbs up!

  30. svet

    I followed your tutorial and added description to my menu. Thanks! However, when I am in mobile mode menu converts into dropdown menu and menu title and description are connected. For example, if my menu item is “about” and description “more about me”, the mobile version shows “aboutmore about me”. Is there a way to fix this?

    • David

      I had the same problem. Here’s what I did.

      I changed this:
      $description = ! empty( $item->description ) ? ‘<span>’.esc_attr( $item->description ).'</span>’ : ”;

      To this:
      $description = ! empty( $item->description ) ? ‘<br /><span>’.esc_attr( $item->description ).'</span>’ : ”;

      Not sure if it’s the best solution, but it worked for me.

      • Garrett Hyder

        Thanks guys, I ran into what SVET and DAVID did with the mobile menu.
        The code seems to have changed my change was simply appending in a span with the dash seperator and in my desktop query simply suppressed it as was unneeded there.

        $item_output .= ‘ – ‘;

        Within my Desktop Only Query set the span to display none;
        @media only screen and (min-width: 740px) {
        header #submenu li span.dash { display:none; }

        Hope that helps, handled my issue nicely.

  31. Nicola

    Great post – very clear, exactly what I needed and worked perfectly. Thank you!

  32. Samedi Amba

    Thanks for the Great Tutorial. I’ve done the major steps well, as you can see from
    http://ueab.ac.ke/demo/index

    I was stuck with the styling-how do I reduce the space between the Main Menu Label and the description? Your help is greatly appreciated.

    • Editorial Staff

      It has to do with the line-height of your .menu a class of your theme. If you reduce that, then the spacing will reduce itself.

      Yönetici

  33. Chris Rouse

    Great post. I’ve tried to dig into this before but the previous instructions I found were not this easy to follow. I was able to drop the functions.php code in, figure out how to change the walker class in my header file (different for the theme I use, but straight forward), and get things going in about 15 minutes from start to finish.

    One piece that you might want to add is how to include the right border on the last menu item using the :last-child property.


    .menu-item:last-child {
    border-right: 1px solid #ccc;
    }

  34. Damien Carbery

    Instead of extending Walker_Nav_Menu it would be nice (and easier) if a filter was provided e.g.
    If the core code had:
    $item_output .= apply_filters( ‘walker_nav_menu_description’, $item->description);

    Then the custom filter function would just have:
    return ” . $description . ”;

  35. Cathy Earle

    Great info … going to start adding this to my sites. Thank you!

Bir Cevap Bırakın

Yorum bırakmayı seçtiğiniz için teşekkür ederiz. Lütfen tüm yorumların yorum poli̇ti̇kasi uyarınca denetlendiğini ve e-posta adresinizin yayımlanmayacağını unutmayın. Ad alanında anahtar kelime KULLANMAYIN. Kişisel ve anlamlı bir sohbet edelim.