【问题标题】:Display Related products for a specific product attribute value in single product pages在单个产品页面中显示特定产品属性值的相关产品
【发布时间】:2018-10-02 06:25:25
【问题描述】:

在 WooCommerce 中,我为我的产品设置了 COLLECTION_ID 产品属性。

我想在单个产品页面上显示与此COLLECTION_ID 产品属性值相关的所有产品。有什么帮助吗?

【问题讨论】:

    标签: php wordpress woocommerce product custom-taxonomy


    【解决方案1】:

    您必须在函数内的“设置部分”中添加自己的设置。对于已定义的产品属性名称,此函数将获取当前产品的第一个对应术语集(因为一个属性在一个产品中可以有多个术语),并将在“Upsell products”之前显示所有相似产品”和“相关产品”。

    代码

    add_action( 'woocommerce_after_single_product_summary', 'custom_output_product_collection', 12 );
    function custom_output_product_collection(){
    
        ## --- YOUR SETTINGS --- ##
    
        $attribute = "Color"; // <== HERE define your attribute name
        $limit     = "3";     // <== Number of products to be displayed
        $cols      = "3";     // <== Number of columns
        $orderby   = "rand";  // <== Order by argument (random order here)
    
        ## --- THE CODE --- ##
    
        global $post, $wpdb;
    
        // Formatting the attribute
        $attribute = sanitize_title( $attribute );
        $taxonomy  = 'pa_' . $attribute;
    
        // Get the WP_Term object for the current product and the defined product attribute
        $terms = wp_get_post_terms( $post->ID, $taxonomy );
        $term = reset($terms);
    
        // Get all product IDs that have  the same product attribute value (except current product ID)
        $product_ids = $wpdb->get_col( "SELECT DISTINCT tr.object_id
            FROM {$wpdb->prefix}term_relationships as tr
            JOIN {$wpdb->prefix}term_taxonomy as tt ON tt.term_taxonomy_id = tr.term_taxonomy_id
            JOIN {$wpdb->prefix}terms as t ON tt.term_id = t.term_id
            WHERE tt.taxonomy LIKE '$taxonomy' AND t.term_id = '{$term->term_id}' AND tr.object_id != '{$post->ID}'" );
    
        // Convert array values to a coma separated string
        $ids = implode( ',', $product_ids );
    
        ## --- THE OUTPUT --- ##
    
        echo '<section class="'.$attribute.' '.$attribute.'-'.$term->slug.' products">
            <h2>'.__( "Collection", "woocommerce" ).': '.$term->name.'</h2>';
    
        echo do_shortcode("[products ids='$ids' columns='$cols' limit='$limit' orderby='$orderby']");
    
        echo '</section>';
    }
    

    代码进入您的活动子主题(或活动主题)的 function.php 文件中。经过测试并且可以工作。

    【讨论】:

    • 这是一个很棒的代码 sn-p Loic。是否可以修改代码,以便只获取同一产品类别中相同颜色的产品?
    最近更新 更多