WooCommerce - 在单个产品页面上创建自定义产品循环

问题描述 投票:0回答:2

我正在开发一个WooCommerce主题,在单个产品页面上,我想显示来自同一供应商类别的产品轮播。

我有以下类别结构:

所有产品

  • 产品类别1
  • 产品类别2
  • 产品猫......

供应商

  • 供应商名称1
  • 供应商名称2
  • 供应商名称 ...

在查看第1类产品时,如果产品被分配到此类子类别,我希望显示来自相同供应商名称类别的其他产品的轮播。

在我的示例中,供应商和所有产品是同一级别的父类别。

做一个自定义的产品循环很容易,但说实话,我不知道如何处理找到合适的子类别背后的逻辑。我无法想象它,这就是我无法想出正确解决方案的原因。

每个产品只能分配给一个供应商名称,供应商和产品都是常规的woocommerce类别。

暂时我有以下代码

wooctrl_same_vendor_products('vendors');

function wooctrl_same_vendor_products($parent_cat_name){

  $parentCat = get_term_by('name', $parent_cat_name, 'product_cat');

  $product_cat_ID = $parentCat->term_id;
  $args = array(
    'hierarchical' => 1,
    'show_option_none' => '',
    'hide_empty' => 0,
    'parent' => $product_cat_ID,
    'taxonomy' => 'product_cat'
  );
  $subcats = get_categories($args);

  foreach ($subcats as $subcat) {
    //check if product is inside ?
  }
}

我应该首先创建所有Vendors子类别的数组并在那里搜索产品,还是有更简洁的方法直接从$ product变量解决它?

php wordpress woocommerce
2个回答
0
投票

我得到了这个工作,但我认为这是一个安静的脏解决方案。您能否看一下代码并告诉我如何以“良好实践”的方式做到这一点?

因此,在第一步中,我正在准备供应商主要类别下的所有子类别列表:

wooctrl_vendor_cats('vendors');  // <-- main category slug

function wooctrl_vendor_cats($parent_cat_name){
$parentCat = get_term_by('name', $parent_cat_name, 'product_cat');

$product_cat_ID = $parentCat->term_id;
$args = array(
    'hierarchical' => 1,
    'show_option_none' => '',
    'hide_empty' => 0,
    'parent' => $product_cat_ID,
    'taxonomy' => 'product_cat'
);
$subcats = get_categories($args);

foreach ($subcats as $subcat) {
    //print_r($subcat->slug);
    check_if_in_vendor($subcat->slug); // <-- here I am passing each slug in order to compare it with products categories
}
}

以下是我与供应商类别交叉引用产品类别以找到匹配项的功能,然后我循环显示其中的所有产品:

function check_if_in_vendor($cat_slug){
global $post;
$terms = wp_get_post_terms( $post->ID, 'product_cat' );
foreach ( $terms as $term ) $categories[] = $term->slug;
if ( in_array( $cat_slug, $categories ) ) {

    $args = array(
        'post_type' => 'product',
        'posts_per_page' => 10,
        'product_cat' => $cat_slug,
        'orderby' => 'rand',
        'post__not_in' => array( $post->ID )
    );
    $loop = new WP_Query( $args );
    while ( $loop->have_posts() ) : $loop->the_post();  ?>



        <li class="product">

            <h3><?php the_title(); ?></h3>

        </li>

    <?php endwhile; ?>
    <?php wp_reset_query();
}
} 

0
投票

在阅读了安德鲁评论并阅读那里提供的文档(以前从未见过的文档,所以感谢安德鲁!那些给了我很多)我决定按照SKU代码的第一部分过滤产品,因为我发现它最快。从WP管理面板管理输出内容也更容易。

这是我用WooCommerce 3功能更新的代码。它比以前的解决方案更好吗?你怎么看?

function wooctrl_display_vendor_products_bySKU($number_of_products_displayed, $ordered_by) {
global $product;
$currentSku = $product->get_sku();
$groupSku = explode('-', $currentSku)[0];

$args = array(
    'sku' => $groupSku,
    'post_type' => 'product',
    'posts_per_page' => $number_of_products_displayed,
    'orderby' => $ordered_by,
    'exclude' => array($product->get_id())
);
$query = new WC_Product_Query($args);
$sku_products = $query->get_products();
//print_r($products);
if ($sku_products) : ?>


    <div class="wrapper">
        <h1 class="section-header"> <?php echo __('Same vendor products', 'genesis-wooctrl') ?> </h1>


        <?php foreach ($sku_products as $sku_product) : ?>

            <?php
            $post_object = get_post($sku_product->get_id());
            setup_postdata($GLOBALS['post'] =& $post_object);
            wc_get_template_part('content', 'product'); ?>

        <?php endforeach; ?>


    </div>


<?php endif;
wp_reset_postdata();
}

对于那些正在寻求可靠功能来源的人来说,这里的URL帮助我解决了这个问题:

https://businessbloomer.com/woocommerce-easily-get-product-info-title-sku-desc-product-object/

https://github.com/woocommerce/woocommerce/wiki/Product-Data-Schema

© www.soinside.com 2019 - 2024. All rights reserved.