Intereting Posts
Категория WordPress и цикл таксономии с разбивкой на страницы Удаление иерархических страниц в постоянной ссылке Форма поиска не работает с пользовательским запросом? Параметры GET мешают моим настройкам плагина Как получить зарегистрированное имя боковой панели по его идентификатору? Статическая страница не работает Добавление популярных сообщений по категориям в одном сообщении? Петля со слайдером (слайдер не загружается) Имя родительского меню доступа Walker_Nav_menu Использование различной wp_nav_menu theme_location на основе идентификатора страницы (или родительского идентификатора) Интересный пользовательский тип сообщения с таксономией и пользовательским полем добавить дополнительный параметр в ловушку по умолчанию в wordpress Как проверить пароль вне WordPress? Пожалуйста, объясните мне, что делает do_action Как запросить пользовательскую таблицу db?

Проверьте, что такое «тип» элемента меню

Вопрос

Я хотел бы проверить, какой тип элемента меню каждый элемент в моем меню, т. Е. Это страница, категория или пользовательская ссылка.

Что я хочу достичь

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

Это меню будет использоваться на сайте электронной торговли с постоянно изменяющимся каталогом. Создание динамического меню, которое скрывает пустые категории, устраняет необходимость постоянного обновления меню в области администратора.

Что у меня сейчас

Пользовательское меню walker, основанное на этом сообщении SE, которое успешно скрывает ссылки на пустые категории, добавляя логику к функции start_el . К сожалению, моя логика скрывает ссылки на страницы

Функция полного ходока:

 function cs_modify_nav_menu_args( $args ){ if( 'primary-menu' == $args['theme_location'] ){ $args['walker'] = new cs_walker_nav_menu(); } return $args; } class cs_walker_nav_menu extends Walker_Nav_Menu { // filter empty categories and add main/sub classes to li's and links function start_el( &$output, $item, $depth = 0, $args = array(), $id = 0 ) { global $wp_query; if(!is_page($item->ID)){ $non_empty_categories = get_categories(array('taxonomy' => 'product_cat')); $empty_categories = array(); $is_empty = true; // check menu items are for an empty category foreach ( $non_empty_categories as $cat ) if ($item->object_id === $cat->term_id) $is_empty = false; // if it is empty add it to array if ($is_empty) $empty_categories[] = $item->ID; // Don't build nav item for items in the is_empty array foreach( $empty_categories as $category_to_skip ) if( $item->ID == $category_to_skip ) return $output; } $indent = ( $depth > 0 ? str_repeat( "\t", $depth ) : '' ); // code indent // depth dependent classes $depth_classes = array( ( $depth == 0 ? 'main-menu-item' : 'sub-menu-item' ), ( $depth >=2 ? 'sub-sub-menu-item' : '' ), ( $depth % 2 ? 'menu-item-odd' : 'menu-item-even' ), 'menu-item-depth-' . $depth ); $depth_class_names = esc_attr( implode( ' ', $depth_classes ) ); // passed classes $classes = empty( $item->classes ) ? array() : (array) $item->classes; $class_names = esc_attr( implode( ' ', apply_filters( 'nav_menu_css_class', array_filter( $classes ), $item ) ) ); // build html $output .= $indent . '<li id="nav-menu-item-'. $item->ID . '" class="' . $depth_class_names . ' ' . $class_names . '">'; // link attributes $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 ) .'"' : ''; $attributes .= ' class="menu-link ' . ( $depth > 0 ? 'sub-menu-link' : 'main-menu-link' ) . '"'; $item_output = sprintf( '%1$s<a%2$s>%3$s%4$s%5$s</a>%6$s', $args->before, $attributes, $args->link_before, apply_filters( 'the_title', $item->title, $item->ID ), $args->link_after, $args->after ); // build html $output .= apply_filters( 'walker_nav_menu_start_el', $item_output, $item, $depth, $args ); } } тем function cs_modify_nav_menu_args( $args ){ if( 'primary-menu' == $args['theme_location'] ){ $args['walker'] = new cs_walker_nav_menu(); } return $args; } class cs_walker_nav_menu extends Walker_Nav_Menu { // filter empty categories and add main/sub classes to li's and links function start_el( &$output, $item, $depth = 0, $args = array(), $id = 0 ) { global $wp_query; if(!is_page($item->ID)){ $non_empty_categories = get_categories(array('taxonomy' => 'product_cat')); $empty_categories = array(); $is_empty = true; // check menu items are for an empty category foreach ( $non_empty_categories as $cat ) if ($item->object_id === $cat->term_id) $is_empty = false; // if it is empty add it to array if ($is_empty) $empty_categories[] = $item->ID; // Don't build nav item for items in the is_empty array foreach( $empty_categories as $category_to_skip ) if( $item->ID == $category_to_skip ) return $output; } $indent = ( $depth > 0 ? str_repeat( "\t", $depth ) : '' ); // code indent // depth dependent classes $depth_classes = array( ( $depth == 0 ? 'main-menu-item' : 'sub-menu-item' ), ( $depth >=2 ? 'sub-sub-menu-item' : '' ), ( $depth % 2 ? 'menu-item-odd' : 'menu-item-even' ), 'menu-item-depth-' . $depth ); $depth_class_names = esc_attr( implode( ' ', $depth_classes ) ); // passed classes $classes = empty( $item->classes ) ? array() : (array) $item->classes; $class_names = esc_attr( implode( ' ', apply_filters( 'nav_menu_css_class', array_filter( $classes ), $item ) ) ); // build html $output .= $indent . '<li id="nav-menu-item-'. $item->ID . '" class="' . $depth_class_names . ' ' . $class_names . '">'; // link attributes $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 ) .'"' : ''; $attributes .= ' class="menu-link ' . ( $depth > 0 ? 'sub-menu-link' : 'main-menu-link' ) . '"'; $item_output = sprintf( '%1$s<a%2$s>%3$s%4$s%5$s</a>%6$s', $args->before, $attributes, $args->link_before, apply_filters( 'the_title', $item->title, $item->ID ), $args->link_after, $args->after ); // build html $output .= apply_filters( 'walker_nav_menu_start_el', $item_output, $item, $depth, $args ); } } 

Попытки решения

Объект nav_menu_item не предоставляет тип элемента меню.

Передача $item->ID is_page не возвращается. Я считаю, что $item->ID – это идентификатор элемента меню, а не идентификатор сообщения.

Solutions Collecting From Web of "Проверьте, что такое «тип» элемента меню"

К счастью, для этого есть легкое решение.

Элемент $item в Walker поставляет классы, и если пункт меню является архивом, вы получаете один из них:

  • стандартная таксономия типа меню (общая)
  • menu-item-object-product_cat (product_cat == taxonomyname)

так же как

  • $ item-> type == 'таксономия'
  • $ item-> object == 'your_taxonomy'

Если вы хотите, чтобы эта логика работала для разных Архивов (а не только для product_cat ), вам также необходимо изменить таксономию – опять же, $item удобно доставляет вашу таксономию $item->object .

Теперь вам нужно только изменить ваши и таксономии в вашем Walker

 if( $item->type == 'taxonomy' ) { $non_empty_categories = get_categories( array( 'taxonomy' => $item->object ) ); // ... The rest of your logic works fine } 

Должно работать просто отлично 🙂