信息发布→ 登录 注册 退出

WooCommerce动态显示兄弟分类和直接子分类列表

发布时间:2025-11-18

点击量:

本文提供一个自定义函数,用于在 WooCommerce 产品分类页面动态展示当前分类的兄弟分类以及这些兄弟分类的直接子分类。该函数能够根据当前页面自动调整显示的分类列表,适用于多层级分类结构,并提供详细的代码示例和解释。

在 WooCommerce 中,有时需要根据当前浏览的产品分类,动态展示其兄弟分类和直接子分类,以便用户更方便地导航和浏览相关产品。以下提供一个实现该功能的自定义函数,并详细解释其工作原理和使用方法。

代码实现

function wc_cat_menu() {

  $queried_object       = get_queried_object();
  $taxonomy             = 'product_cat';

  $sibling_terms        = get_terms( array(
    'taxonomy'          => $taxonomy,
    'hide_empty'        => false,
    'parent'            => $queried_object->parent
  ) );

  echo '
    '; foreach( $sibling_terms as $sibling ) { if ( $sibling->parent > 0 ) { $sibling_id = $sibling->term_id; $siblingChildren = get_terms( $taxonomy, array( 'parent' => $sibling_id, 'hide_empty' => false ) ); echo '
  • ' . $sibling->name . ' (' . $sibling->count . ')'; if( $siblingChildren ) { echo '
      '; foreach ( $siblingChildren as $child ) { echo '
    • ' . $child->name . ' (' . $child->count . ')
    • '; } echo '
    '; } echo '
  • '; } } echo '
'; }

代码解释

  1. 获取当前分类对象:$queried_object = get_queried_object(); 使用 get_queried_object() 函数获取当前页面正在浏览的分类对象。

  2. 定义分类法:$taxonomy = 'product_cat'; 指定分类法为 product_cat,即 WooCommerce 的产品分类。

  3. 获取兄弟分类:

    $sibling_terms = get_terms( array(
        'taxonomy' => $taxonomy,
        'hide_empty' => false,
        'parent' => $queried_object->parent
    ) );

    使用 get_terms() 函数获取兄弟分类。parent 参数设置为当前分类对象的父级 ID,从而获取与当前分类同级的分类。hide_empty 设置为 false,表示显示所有分类,即使没有产品。

  4. 循环遍历兄弟分类:foreach( $sibling_terms as $sibling ) { ... } 循环遍历获取到的兄弟分类。

  5. 排除顶级分类:if ( $sibling->parent > 0 ) { ... } 只显示有父级分类的分类,排除顶级分类。

  6. 获取子分类:

    $sibling_id = $sibling->term_id;
    
    $siblingChildren  = get_terms( $taxonomy, array(
        'parent'        => $sibling_id,
        'hide_empty'    => false
    ) );

    使用 get_terms() 函数获取当前兄弟分类的子分类,parent 参数设置为当前兄弟分类的ID。

  7. 输出 HTML 结构: 代码中使用 echo 输出 HTML 结构,包括

    • 标签,用于构建分类列表。使用 get_term_link() 函数获取分类链接,并显示分类名称和产品数量。

使用方法

将上述代码添加到你的主题的 functions.php 文件中,然后在需要显示分类列表的位置调用 wc_cat_menu() 函数。例如,可以在 WooCommerce 的侧边栏或者产品分类页面中使用。

注意事项

  • 确保在 WooCommerce 环境中使用此代码。
  • 可以根据需要修改 HTML 结构和 CSS 样式,以适应你的主题风格。
  • 此代码仅显示兄弟分类和直接子分类,不显示更深层级的子分类。

总结

通过使用上述自定义函数,可以方便地在 WooCommerce 产品分类页面动态展示当前分类的兄弟分类和直接子分类,从而提升用户体验和导航效率。 该函数易于理解和修改,可以根据实际需求进行定制。

标签:# 产品分类  # 产品数量  # 相关产品  # 只显示  # 适用于  # 可以根据  # 提供一个  # 遍历  # 设置为  # 自定义  # css  # li  # ul  # 对象  # 循环  # foreach  # if  # echo  # html  # php  
在线客服
服务热线

服务热线

4008888355

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!