Woocommerce获得产品

Tes*_*ter 39 php wordpress woocommerce

我使用以下代码在我的WordPress网站上获取WooCommerce的产品类别列表:

 <?php
  $taxonomy     = 'product_cat';
  $orderby      = 'name';  
  $show_count   = 0;      // 1 for yes, 0 for no
  $pad_counts   = 0;      // 1 for yes, 0 for no
  $hierarchical = 0;      // 1 for yes, 0 for no  
  $title        = '';  
  $empty        = 0;
$args = array(
  'taxonomy'     => $taxonomy,
  'orderby'      => $orderby,
  'show_count'   => $show_count,
  'pad_counts'   => $pad_counts,
  'hierarchical' => $hierarchical,
  'title_li'     => $title,
  'hide_empty'   => $empty
);
?>
<?php $all_categories = get_categories( $args );

//print_r($all_categories);
foreach ($all_categories as $cat) {
    //print_r($cat);
    if($cat->category_parent == 0) {
        $category_id = $cat->term_id;

?>     

<?php       

        echo '<br /><a href="'. get_term_link($cat->slug, 'product_cat') .'">'. $cat->name .'</a>'; ?>


        <?php
        $args2 = array(
          'taxonomy'     => $taxonomy,
          'child_of'     => 0,
          'parent'       => $category_id,
          'orderby'      => $orderby,
          'show_count'   => $show_count,
          'pad_counts'   => $pad_counts,
          'hierarchical' => $hierarchical,
          'title_li'     => $title,
          'hide_empty'   => $empty
        );
        $sub_cats = get_categories( $args2 );
        if($sub_cats) {
            foreach($sub_cats as $sub_category) {
                echo  $sub_category->name ;
            }

        } ?>



    <?php }     
}
?>
Run Code Online (Sandbox Code Playgroud)

这很好,并返回产品类别列表.我一直在努力获取特定类别的产品列表.

示例:获取所有产品cat_id=34.

我知道产品存储为帖子,并且一直试图完成这项工作,但似乎无法做到.

如何获取特定类别的产品列表?

Sum*_*n95 66

<?php  
    $args = array(
        'post_type'      => 'product',
        'posts_per_page' => 10,
        'product_cat'    => 'hoodies'
    );

    $loop = new WP_Query( $args );

    while ( $loop->have_posts() ) : $loop->the_post();
        global $product;
        echo '<br /><a href="'.get_permalink().'">' . woocommerce_get_product_thumbnail().' '.get_the_title().'</a>';
    endwhile;

    wp_reset_query();
?>
Run Code Online (Sandbox Code Playgroud)

这将列出所有产品缩略图和名称及其到产品页面的链接.根据您的要求更改类别名称和posts_per_page.

  • 如果要在代码中的嵌套内循环中使用它,请使用'product_cat'=> $ sub_category-> slug. (2认同)
  • 你们中的一些人只是天才.应该有一种方式奖励非常有帮助的评论/人:) (2认同)

Hun*_*Dev 25

<?php
$args     = array( 'post_type' => 'product', 'category' => 34, 'posts_per_page' => -1 );
$products = get_posts( $args ); 
?>
Run Code Online (Sandbox Code Playgroud)

这应该抓住你想要的所有产品,我可能有错误的帖子类型虽然我不太记得woo-commerce用于帖子类型.它将返回一系列产品


Chr*_*yer 24

不要使用WP_Query()get_posts().来自WooCommerce doc:

wc_get_products和WC_Product_Query提供了一种检索产品的标准方法,这些产品可以安全使用,并且不会因未来WooCommerce版本中的数据库更改而中断.构建自定义WP_Queries或数据库查询可能会在未来版本的WooCommerce中破坏您的代码,因为数据会转向自定义表以获得更好的性能.

您可以像这样检索所需的产品:

$args = array(
    'category' => array( 34 ),
    'orderby'  => 'name',
);
$products = wc_get_products( $args );
Run Code Online (Sandbox Code Playgroud)

WooCommerce文档

  • 这不适用于类别 ID。它期望类别 slug。 (2认同)