あなたが親ページにいる場合、私はこのコードを使ってカスタムメニューサブページを表示しています。しかし、このコードが示しているのはサブメニューのないページの親ページです。これは非表示にします。基本的にこのコードを使用するのは、サブページがあるページにいる場合だけです。
class Selective_Walker extends Walker_Nav_Menu
{
function walk( $elements, $max_depth) {
$args = array_slice(func_get_args(), 2);
$output = '';
if ($max_depth < -1) //invalid parameter
return $output;
if (empty($elements)) //nothing to walk
return $output;
$id_field = $this->db_fields['id'];
$parent_field = $this->db_fields['parent'];
// flat display
if ( -1 == $max_depth ) {
$empty_array = array();
foreach ( $elements as $e )
$this->display_element( $e, $empty_array, 1, 0, $args, $output );
return $output;
}
/*
* need to display in hierarchical order
* separate elements into two buckets: top level and children elements
* children_elements is two dimensional array, eg.
* children_elements[10][] contains all sub-elements whose parent is 10.
*/
$top_level_elements = array();
$children_elements = array();
foreach ( $elements as $e) {
if ( 0 == $e->$parent_field )
$top_level_elements[] = $e;
else
$children_elements[ $e->$parent_field ][] = $e;
}
/*
* when none of the elements is top level
* assume the first one must be root of the sub elements
*/
if ( empty($top_level_elements) ) {
$first = array_slice( $elements, 0, 1 );
$root = $first[0];
$top_level_elements = array();
$children_elements = array();
foreach ( $elements as $e) {
if ( $root->$parent_field == $e->$parent_field )
$top_level_elements[] = $e;
else
$children_elements[ $e->$parent_field ][] = $e;
}
}
$current_element_markers = array( 'current-menu-item', 'current-menu-parent', 'current-menu-ancestor' ); //added by continent7
foreach ( $top_level_elements as $e ){ //changed by continent7
// descend only on current tree
$descend_test = array_intersect( $current_element_markers, $e->classes );
if ( !empty( $descend_test ) )
$this->display_element( $e, $children_elements, 2, 0, $args, $output );
}
/*
* if we are displaying all levels, and remaining children_elements is not empty,
* then we got orphans, which should be displayed regardless
*/
/* removed by continent7
if ( ( $max_depth == 0 ) && count( $children_elements ) > 0 ) {
$empty_array = array();
foreach ( $children_elements as $orphans )
foreach( $orphans as $op )
$this->display_element( $op, $empty_array, 1, 0, $args, $output );
}
*/
return $output;
}
}
テンプレートを使用して:
wp_nav_menu(
array(
'theme_location'=>'primary',
'walker'=>new Selective_Walker()
)
);
私はこれまでに全く同じ問題をWordpressで何度も経験しています。他のCMSでは、私はメニューに常にstart_depthのオプションがあり、二次メニューや三次メニュー(分割メニュー)を実装するのがとても簡単でした。
Wordpressはこの機能を含んでいません。そして多くのオンラインの解決策はメニューマネージャの階層を完全に無視するwp_list_pagesを使用します。
さまざまなウォーカーやウィジェットを試した後、私はようやくstart_depthオプションを含む自分のプラグインを書くことにしました。
あなたはこのようにそれを使う:
wp_nav_menu(array('theme_location' => 'primary_navigation', 'start_depth' => 1));
興味のある方は、WordPressプラグインリポジトリから無料で入手できます。 https://wordpress.org/plugins/wp-nav-plus/
私はこの問題を解決する無料のプラグインを作りました!
https://wordpress.org/plugins/wp-nav-menu-extended/
このプラグインはネイティブのwp_nav_menu関数を拡張して追加のオプションを追加します。
使用例:
$defaults = array( 'theme_location' => 'main_menu', 'level' => 2, 'child_of' => 'About Us', );
wp_nav_menu( $defaults );