从 WordPress 的 WooCommerce 导航栏中删除 'Empty' Categories/SubCategories
Removing 'Empty' Categories/SubCategories from a WooCommerce NavBar in WordPress
当类别级别中没有产品时,下面的代码允许用户在 WooCommerce 网站上隐藏 'empty' 类别和子类别级别,但我意识到这不是编写此功能的正确方法因为它使用 'product id' 作为参考,当它真的需要参考并对照 进行自我检查时'stock levels' 可能处于上述 category/subcategory 级别的任何产品。
是否有人可以修改以下代码以检查 库存水平 而不是产品 ID?我已经尝试过了,但是没有成功。
function nav_remove_empty_category_menu_item ( $items, $menu, $args ) {
if ( ! is_admin() ) {
global $wpdb;
$nopost = $wpdb->get_col( "SELECT term_taxonomy_id FROM $wpdb->term_taxonomy WHERE count = 0" );
foreach ( $items as $key => $item ) {
if ( ( 'taxonomy' == $item->type ) && ( in_array( $item->object_id, $nopost ) ) ) {
unset( $items[$key] );
}
}
}
return $items;
}
add_filter( 'wp_get_nav_menu_items', 'nav_remove_empty_category_menu_item', 10, 3 );
这个答案实际上是由了不起的 Md. Mehedi Hasan 最终为我整理的,所以完全归功于他!
function nav_remove_empty_category_menu_item ( $items, $menu) {
if ( ! is_admin() ) {
$args = array(
'hide_empty' => false,
'hierarchical' => true,
);
$product_categories = get_terms( 'product_cat', $args );
$exclude = array();
foreach ( $product_categories as $category ) {
$posts = get_posts( array( 'post_type' => 'product', 'posts_per_page' => -1, 'product_cat' => $category->slug, 'fields' => 'ids' ) );
$show_category = false;
foreach ( $posts as $post ) {
$product = new wC_Product( $post );
$visible_product = $product->is_visible();
if ( true === $visible_product ) {
$show_category = true;
break;
}
}
if ( false === $show_category ) {
$exclude[] = $category->term_id;
}
}
global $wpdb;
$nopost = $wpdb->get_col( "SELECT term_taxonomy_id FROM $wpdb->term_taxonomy WHERE count = 0" );
foreach ( $items as $key => $item ) {
if ( ( 'taxonomy' == $item->type ) && ( in_array( $item->object_id, $exclude ) ) ) {
unset( $items[$key] );
}
}
}
return $items;
}
add_filter( 'wp_get_nav_menu_items', 'nav_remove_empty_category_menu_item', 10, 3 );
当类别级别中没有产品时,下面的代码允许用户在 WooCommerce 网站上隐藏 'empty' 类别和子类别级别,但我意识到这不是编写此功能的正确方法因为它使用 'product id' 作为参考,当它真的需要参考并对照 进行自我检查时'stock levels' 可能处于上述 category/subcategory 级别的任何产品。
是否有人可以修改以下代码以检查 库存水平 而不是产品 ID?我已经尝试过了,但是没有成功。
function nav_remove_empty_category_menu_item ( $items, $menu, $args ) {
if ( ! is_admin() ) {
global $wpdb;
$nopost = $wpdb->get_col( "SELECT term_taxonomy_id FROM $wpdb->term_taxonomy WHERE count = 0" );
foreach ( $items as $key => $item ) {
if ( ( 'taxonomy' == $item->type ) && ( in_array( $item->object_id, $nopost ) ) ) {
unset( $items[$key] );
}
}
}
return $items;
}
add_filter( 'wp_get_nav_menu_items', 'nav_remove_empty_category_menu_item', 10, 3 );
这个答案实际上是由了不起的 Md. Mehedi Hasan 最终为我整理的,所以完全归功于他!
function nav_remove_empty_category_menu_item ( $items, $menu) {
if ( ! is_admin() ) {
$args = array(
'hide_empty' => false,
'hierarchical' => true,
);
$product_categories = get_terms( 'product_cat', $args );
$exclude = array();
foreach ( $product_categories as $category ) {
$posts = get_posts( array( 'post_type' => 'product', 'posts_per_page' => -1, 'product_cat' => $category->slug, 'fields' => 'ids' ) );
$show_category = false;
foreach ( $posts as $post ) {
$product = new wC_Product( $post );
$visible_product = $product->is_visible();
if ( true === $visible_product ) {
$show_category = true;
break;
}
}
if ( false === $show_category ) {
$exclude[] = $category->term_id;
}
}
global $wpdb;
$nopost = $wpdb->get_col( "SELECT term_taxonomy_id FROM $wpdb->term_taxonomy WHERE count = 0" );
foreach ( $items as $key => $item ) {
if ( ( 'taxonomy' == $item->type ) && ( in_array( $item->object_id, $exclude ) ) ) {
unset( $items[$key] );
}
}
}
return $items;
}
add_filter( 'wp_get_nav_menu_items', 'nav_remove_empty_category_menu_item', 10, 3 );