2016-12-11 3 views
0

Ich habe meinem Wordpress-Theme ein Dropdown-Menü hinzugefügt. Ich habe es installiert und es funktioniert gut. Jetzt möchte ich jedoch die neuesten Beiträge aus jeder Kategorie im Dropdown-Menü anzeigen. Kann mir jemand helfen, mich in die richtige Richtung zu lenken?So zeigen Sie die neuesten Posts aus jeder Kategorie im Dropdown-Menü an

ein Beispiel dafür, was ich suche enter image description here

Hier ist der aktuelle Code meines Drop-Down-Menü

class CSS_Menu_Walker extends Walker { 
 
    
 
var $db_fields = array('parent' => 'menu_item_parent', 'id' => 'db_id'); 
 
function start_lvl(&$output, $depth = 0, $args = array()) { 
 
$indent = str_repeat("\t", $depth); 
 
$output .= "\n$indent<ul>\n"; 
 
} 
 
function end_lvl(&$output, $depth = 0, $args = array()) { 
 
$indent = str_repeat("\t", $depth); 
 
$output .= "$indent</ul>\n"; 
 
} 
 
function start_el(&$output, $item, $depth = 0, $args = array(), $id = 0) { 
 
global $wp_query; 
 
$indent = ($depth) ? str_repeat("\t", $depth) : ''; 
 
$class_names = $value = ''; 
 
$classes = empty($item->classes) ? array() : (array) $item->classes; 
 
/* Add active class */ 
 
if (in_array('current-menu-item', $classes)) { 
 
$classes[] = 'active'; 
 
unset($classes['current-menu-item']); 
 
} 
 
/* Check for children */ 
 
$children = get_posts(array('post_type' => 'nav_menu_item', 'nopaging' => true, 'numberposts' => 1, 'meta_key' => '_menu_item_menu_item_parent', 'meta_value' => $item->ID)); 
 
if (!empty($children)) { 
 
$classes[] = 'has-sub'; 
 
} 
 
$class_names = join(' ', apply_filters('nav_menu_css_class', array_filter($classes), $item, $args)); 
 
$class_names = $class_names ? ' class="' . esc_attr($class_names) . '"' : ''; 
 
$id = apply_filters('nav_menu_item_id', 'menu-item-'. $item->ID, $item, $args); 
 
$id = $id ? ' id="' . esc_attr($id) . '"' : ''; 
 
$output .= $indent . '<li' . $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 .'><span>'; 
 
$item_output .= $args->link_before . apply_filters('the_title', $item->title, $item->ID) . $args->link_after; 
 
$item_output .= '</span></a>'; 
 
$item_output .= $args->after; 
 
$output .= apply_filters('walker_nav_menu_start_el', $item_output, $item, $depth, $args); 
 
} 
 
function end_el(&$output, $item, $depth = 0, $args = array()) { 
 
$output .= "</li>\n"; 
 
} 
 
}

Antwort

2

Diese Methode verwendet die eingebaute in wp_get_recent_posts Funktion. Sie müssen lediglich den folgenden Code in die functions.php-Datei Ihres Themes oder ein Site-spezifisches Plugin kopieren und einfügen.

function wpb_recentposts_dropdown() { 
$string .= '<select id="rpdropdown"> 
    <option value="" selected>Select a Post<option>'; 

$args = array('numberposts' => '5', 'post_status' => 'publish'); 

$recent_posts = wp_get_recent_posts($args); 
    foreach($recent_posts as $recent){ 
     $string .= '<option value="' . get_permalink($recent["ID"]) . '">' . $recent["post_title"].'</option> '; 
} 

$string .= '</select> 
    <script type="text/javascript"> var urlmenu = document.getElementById("rpdropdown"); urlmenu.onchange = function() { 
     window.open(this.options[ this.selectedIndex ].value, "_self"); 
    }; 
    </script>'; 

return $string; 
} 
add_shortcode('rp_dropdown', 'wpb_recentposts_dropdown'); 
add_filter('widget_text','do_shortcode'); 
+0

Aber erlaubt dies mir die Beiträge im Dropdown-Menü wie im obigen Beispiel hinzuzufügen? – user6738171

Verwandte Themen