You need to enable JavaScript to run this app.
最新活动
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

使用儿童类别作为后备的WooCommerce相关产品,以Rank Math主要类别排序

以下是使用儿童类别作为后备的WooCommerce相关产品,并使用Rank Math主要类别排序的代码示例:

// 添加自定义的排序选项到产品排序下拉菜单
add_filter('woocommerce_get_catalog_ordering_args', 'child_category_fallback_sorting');
function child_category_fallback_sorting($args) {
    $orderby_value = isset($_GET['orderby']) ? wc_clean($_GET['orderby']) : apply_filters('woocommerce_default_catalog_orderby', get_option('woocommerce_default_catalog_orderby'));

    if ('child_category' == $orderby_value) {
        $args['orderby'] = 'menu_order title';
        $args['order'] = 'ASC';
        $args['meta_query'] = array(
            'relation' => 'OR',
            array(
                'key' => '_rank_math_primary_category',
                'compare' => 'NOT EXISTS',
            ),
            array(
                'key' => '_rank_math_primary_category',
                'value' => '',
                'compare' => '=',
            ),
        );
    }

    return $args;
}

// 修改产品排序下拉菜单显示的文本
add_filter('woocommerce_catalog_orderby', 'child_category_fallback_sorting_options');
function child_category_fallback_sorting_options($options) {
    $options['child_category'] = '使用儿童类别作为后备';

    return $options;
}

// 排除儿童类别的产品排序
add_filter('posts_clauses', 'child_category_fallback_sorting_exclude_child_category');
function child_category_fallback_sorting_exclude_child_category($clauses) {
    global $wpdb;
    $orderby_value = isset($_GET['orderby']) ? wc_clean($_GET['orderby']) : apply_filters('woocommerce_default_catalog_orderby', get_option('woocommerce_default_catalog_orderby'));

    if ('child_category' == $orderby_value) {
        $clauses['join'] .= "
            LEFT JOIN {$wpdb->term_relationships} AS tr ON {$wpdb->posts}.ID = tr.object_id
            LEFT JOIN {$wpdb->term_taxonomy} AS tt ON (tr.term_taxonomy_id = tt.term_taxonomy_id AND tt.taxonomy = 'product_cat')
            LEFT JOIN {$wpdb->terms} AS t ON (tt.term_id = t.term_id AND t.term_id NOT IN (
                SELECT parent
                FROM {$wpdb->term_taxonomy}
                WHERE taxonomy = 'product_cat' AND parent != 0
            ))
        ";
        $clauses['where'] .= " AND (t.term_id IS NULL OR t.term_id = 0)";
    }

    return $clauses;
}

请确保将上述代码放置在您的活动主题(或自定义插件)的functions.php文件中。这将添加一个名为“使用儿童类别作为后备”的排序选项到产品排序下拉菜单,并按照Rank Math主要类别排序产品。如果产品没有设置主要类别或主要类别不是儿童类别,它们将被作为后备排序。

本文内容通过AI工具匹配关键字智能整合而成,仅供参考,火山引擎不对内容的真实、准确或完整作任何形式的承诺。如有任何问题或意见,您可以通过联系service@volcengine.com进行反馈,火山引擎收到您的反馈后将及时答复和处理。
展开更多
面向开发者的云福利中心,ECS 60元/年,域名1元起,助力开发者快速在云上构建可靠应用

社区干货

特惠活动

热门爆款云服务器

100%性能独享,更高内存性能更佳,学习测试、web前端、企业应用首选,每日花费低至0.55元
60.00/1212.00/年
立即购买

域名注册服务

cn/top/com等热门域名,首年低至1元,邮箱建站必选
1.00/首年起32.00/首年起
立即购买

DCDN国内流量包100G

同时抵扣CDN与DCDN两种流量消耗,加速分发更实惠
2.00/20.00/年
立即购买

使用儿童类别作为后备的WooCommerce相关产品,以Rank Math主要类别排序-优选内容

使用儿童类别作为后备的WooCommerce相关产品,以Rank Math主要类别排序-相关内容

特惠活动

热门爆款云服务器

100%性能独享,更高内存性能更佳,学习测试、web前端、企业应用首选,每日花费低至0.55元
60.00/1212.00/年
立即购买

域名注册服务

cn/top/com等热门域名,首年低至1元,邮箱建站必选
1.00/首年起32.00/首年起
立即购买

DCDN国内流量包100G

同时抵扣CDN与DCDN两种流量消耗,加速分发更实惠
2.00/20.00/年
立即购买

产品体验

体验中心

云服务器特惠

云服务器
云服务器ECS新人特惠
立即抢购

白皮书

一图详解大模型
浓缩大模型架构,厘清生产和应用链路关系
立即获取

最新活动

爆款1核2G共享型服务器

首年60元,每月仅需5元,限量秒杀
立即抢购

火山引擎增长体验专区

丰富能力激励企业快速增长
查看详情

数据智能VeDI

易用的高性能大数据产品家族
了解详情

一键开启云上增长新空间

立即咨询