2016-04-01 269 views
0

我已經創建了一些自定義類別的產品,它有子類別和子類別有更多的子類別。現在首先顯示主要類別。如果我在那裏顯示子,那麼顯示與該類別及其子類別相關的所有子類別。我想逐步顯示它們。也就是說,如果用戶點擊主類別然後進入其子類別頁面。如果用戶點擊其中一個子類別,則應該轉到子類別,如果沒有子類別,則顯示該產品。代碼是類別和子類別wordpress

$products = get_term_children($term_id[0], 'product-cat'); 
if(count($products) > 0){ 
    $count = 0; 
    $sorted_products = array(); 

    foreach ($products as $product) { 

     $sorted_products = get_term($product, 'product-cat'); 
     $prod_meta = get_option("taxonomy_term_".$term->term_id); 
    //echo "<pre>"; print_r($sorted_products); 

    foreach ($sorted_products as $product) { ?> 
      <div class="col-md-3 col-sm-4 col-xs-12"> 
        <a href="<?php echo $product['link']; ?>"> 
         <a href="<?php echo $product['link']; ?>" class="hvr-grow"> 
          <img class="center-block img-responsive" src="<?php echo $product['img'] ? $product['img'] : '/wp-content/themes/ruskin/images/dummy-product.jpg'; ?>" alt="<?php echo $product['name']; ?>"> 
        <h3><a href="<?php echo $product['link']; ?>"><?php echo $product['name']; ?></a></h3> 
else{ 

    # Define the WP Query post arguments. 
    $args = array(
    'post_status' => 'publish', 
    'post_type' => 'products', 
    'posts_per_page' => -1, 
    //'meta_query' => array('relation' => 'AND', array('key' => '_cus__featured', 'value' => '1', 'compare' => '='),), 
    'meta_key' => '_cus__sort_order', 
    //'meta_value' => 'meta_value', 
    'orderby' => 'meta_value_num', 
    'order' => 'ASC', 
    'tax_query' => array(
     array('taxonomy' => 'product-cat', 
      'field' => 'slug', 
      'terms' => $cats 
     ))); 
$loop = new WP_Query($args); 
$total = $loop->found_posts; 
$sliders=''; 
// Generatet the slider conteents 
while ($loop->have_posts()) { 
    $loop->the_post(); 
    $listingimg = get_post_custom_values('_cus__listing_img'); 
     $listingimg = "/wp-content/themes/bodyo/images/no-slider-img.jpg"; 

    $img = wp_get_attachment_image_src(get_post_thumbnail_id($post->ID), 'main_slide_img'); 
     $img = "/wp-content/themes/bodyo/images/no-slider-img.jpg"; 
    $sliders .= '<a href="'. get_the_permalink() .'" class="hvr-grow">'; 
    $sliders .= '<img src="'.$listingimg.'" class="center-block img-responsive" alt="'. get_the_title() .'" />'; 
    $sliders .= '</a>'; 
    $sliders .= '</div>'; 
    $sliders .= '<a href="'. get_the_permalink() .'">'; 
    $sliders .= '<h3>'. get_the_title() .'</h3>'; 
    $sliders .= '<p>'. get_the_excerpt() .'</p>'; 
    $sliders .= '<a href="'. get_the_permalink() .'">read more</a>'; 
    $counter++; 

} 

它覆蓋了以前的排序順序。也就是說,如果從儀表板中按排序順序給出2到3個類別,那麼它只顯示最後一個。前兩個被覆蓋。

回答

0

像這樣的東西應該這樣做。

$args = array(
    'child_of' => $term_id[0], 
    'taxonomy' => 'product-cat', 
    'hierarchical' => true, 
    'depth' => 1, 
); 
$categories = get_categories($args); 

記住get_categories()get_terms()的包裝。

您可以找到所有可接受的值here但您正在尋找的值是深度。

+0

在哪個步驟中可以詳細說明這一點 –

+0

您發佈的代碼的第一行。 –