本文提供一个自定义函数,用于在 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 '
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 '代码解释
获取当前分类对象:$queried_object = get_queried_object(); 使用 get_queried_object() 函数获取当前页面正在浏览的分类对象。
定义分类法:$taxonomy = 'product_cat'; 指定分类法为 product_cat,即 WooCommerce 的产品分类。
获取兄弟分类:
$sibling_terms = get_terms( array(
'taxonomy' => $taxonomy,
'hide_empty' => false,
'parent' => $queried_object->parent
) );使用 get_terms() 函数获取兄弟分类。parent 参数设置为当前分类对象的父级 ID,从而获取与当前分类同级的分类。hide_empty 设置为 false,表示显示所有分类,即使没有产品。
循环遍历兄弟分类: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
) );使用 get_terms() 函数获取当前兄弟分类的子分类,parent 参数设置为当前兄弟分类的ID。
输出 HTML 结构: 代码中使用 echo 输出 HTML 结构,包括
使用方法
将上述代码添加到你的主题的 functions.php 文件中,然后在需要显示分类列表的位置调用 wc_cat_menu() 函数。例如,可以在 WooCommerce 的侧边栏或者产品分类页面中使用。
注意事项
总结
通过使用上述自定义函数,可以方便地在 WooCommerce 产品分类页面动态展示当前分类的兄弟分类和直接子分类,从而提升用户体验和导航效率。 该函数易于理解和修改,可以根据实际需求进行定制。