問題描述
我知道如何將 Walker 新增到由主題 (本例中為 primary 的選單) 建立的自定義選單中,但是如何使用預設的 wordpress 自定義選單小工具來定位在小工具中建立的選單?
if ( has_nav_menu( 'primary' ) ) {
$args = array(
'menu' => 'main-menu',
'menu_id' => 'main-menu',
'theme_location' => 'primary',
'depth' => 0,
'container' => false,
'menu_class' => 'nav',
'walker' => new Myprefix_Walker_Nav_Menu(),
'echo' => 0
);
$nav = wp_nav_menu( $args );
}
最佳解決方案
如果您檢視 WP_Nav_Menu_Widget 類的實現,您將看到以下程式碼:
function widget($args, $instance) {
// Get menu
$nav_menu = ! empty( $instance['nav_menu'] ) ? wp_get_nav_menu_object( $instance['nav_menu'] ) : false;
if ( !$nav_menu )
return;
$instance['title'] = apply_filters( 'widget_title', empty( $instance['title'] ) ? '' : $instance['title'], $instance, $this->id_base );
echo $args['before_widget'];
if ( !empty($instance['title']) )
echo $args['before_title'] . $instance['title'] . $args['after_title'];
wp_nav_menu( array( 'fallback_cb' => '', 'menu' => $nav_menu ) );
echo $args['after_widget'];
}
這意味著沒有任何機會勾選選單。所以你需要看看 wp_nav_menu 的功能實現,在那裡你可以找到以下程式碼行:
$defaults = array( 'menu' => '', 'container' => 'div', 'container_class' => '', 'container_id' => '', 'menu_class' => 'menu', 'menu_id' => '',
'echo' => true, 'fallback_cb' => 'wp_page_menu', 'before' => '', 'after' => '', 'link_before' => '', 'link_after' => '', 'items_wrap' => '<ul id="%1$s" class="%2$s">%3$s</ul>',
'depth' => 0, 'walker' => '', 'theme_location' => '' );
$args = wp_parse_args( $args, $defaults );
$args = apply_filters( 'wp_nav_menu_args', $args );
$args = (object) $args;
這裡可以看到傳遞給 wp_nav_menu 函式的所有引數都可以被替換。所以你需要的是建立自己的鉤子處理程序,這將把你的步行器新增到導航選單中。這可能很簡單:
function myplugin_custom_walker( $args ) {
return array_merge( $args, array(
'walker' => new My_Custom_Walker(),
// another setting go here ...
) );
}
add_filter( 'wp_nav_menu_args', 'myplugin_custom_walker' );
次佳解決方案
擴充套件 @ Eugene 的答案,如果你想限制一個特定的選單,只需檢查選單的術語 ID:
function custom_nav_args($args){
$menu = $args['menu'];
if($menu->term_id === 17) /* replace term_id with menu id, or use $menu->name to do it by menu name*/
{
$args['walker'] = new My_Custom_Walker();
}
return $args;
}
add_filter('wp_nav_menu_args', 'custom_nav_args');
參考文獻
注:本文內容整合自 Google/Baidu/Bing 輔助翻譯的英文資料結果。如果您對結果不滿意,可以加入我們改善翻譯效果:薇曉朵技術論壇。