WooCommerce在产品循环中将产品类别添加为类

时间:2014-01-24 12:51:46

标签: php wordpress woocommerce product

我正在开一家小型Woocommerce商店,我希望有一个分类功能。 排序就像一个魅力,但它是基于产品类进行排序。 所以我想在产品循环中的列表项上将产品类别作为类发布。 我的循环看起来像这样:

<?php
    $args = array(
      'post_type' => 'product',
      'posts_per_page' => 999
      );
    $loop = new WP_Query( $args );
    if ( $loop->have_posts() ) {
        while ( $loop->have_posts() ) : $loop->the_post();
            woocommerce_get_template_part( 'content', 'product' );
        endwhile;
    } 
    else {
      echo __( 'No products found' );
    }
    wp_reset_postdata();
?>

它输出每个项目的列表项,如下所示:

<li class="post-15 product type-product status-publish hentry first instock">
    <a href="http://shop.bbpixelz.dk/product/i-phone-ai-template/">
        <img width="150" height="150" src="http://shop.bbpixelz.dk/wp-content/uploads/2014/01/iphone-ai-template-150x150.png" class="attachment-shop_catalog wp-post-image" alt="iphone-ai-template">
        <h3>I-Phone Vector Template</h3>
    <span class="price"><span class="amount">$2</span></span>
    </a>
    <a href="/?add-to-cart=15" rel="nofollow" data-product_id="15" data-product_sku="ai-iphone" class="add_to_cart_button button product_type_simple">Add to cart</a>
</li>

我想将产品类别添加为li的类。这是怎么做到的?

1 个答案:

答案 0 :(得分:1)

这些类是由WordPress post_class()函数生成的,如content-product.php模板中所示:

<li <?php post_class( $classes ); ?>>

关于如何向帖子类添加类别,有一个很好的example in the Codex。修改我们的产品类别:

// add product category name to post class
function category_id_class( $classes ) {
    global $post;
    $product_cats = get_the_terms( $post->ID, 'product_cat' );
    if( $product_cats ) foreach ( $product_cats as $category ) {
        $classes[] = $category->name;
    }
    return $classes;
}
add_filter( 'post_class', 'category_id_class' );