0

0

如何在WCFM商家店铺页按分类展示商品

心靈之曲

心靈之曲

发布时间:2026-02-19 14:50:06

|

932人浏览过

|

来源于php中文网

原创

如何在WCFM商家店铺页按分类展示商品

本文介绍如何通过自定义短代码,在wcfm marketplace插件的商家店铺页面中,按商品分类(如蔬菜、水果)分组展示该商家所售商品,实现“每类一栏、分类陈列”的专业店铺布局。

本文介绍如何通过自定义短代码,在wcfm marketplace插件的商家店铺页面中,按商品分类(如蔬菜、水果)分组展示该商家所售商品,实现“每类一栏、分类陈列”的专业店铺布局。

在 WooCommerce + WCFM Marketplace 环境下,商家店铺页默认仅通过侧边栏小工具展示分类导航,但缺乏正文区域的结构化商品呈现。若需实现类似以下效果:

VEGETABLES(分类标题)
[产品A] [产品B] [产品C] [产品D]

FRUITS(分类标题)
[产品X] [产品Y] [产品Z]

即「按商家自有商品所属分类动态分组,并在店铺主内容区渲染对应商品列表」,需结合 WordPress 钩子、WCFM API 及 WooCommerce [products] 短代码能力进行定制开发。

✅ 实现原理简述

核心思路是:

名品购物网店系统
名品购物网店系统

适合品牌专卖店专用,从前台的美工设计就开始强调视觉形象,有助于提升商品的档次,打造网店品牌!后台及程序核心比较简洁,着重在线购物,去掉了繁琐的代码及垃圾程式,在结构上更适合一些中高档的时尚品牌商品展示. 率先引入语言包机制,可在1小时内制作出任何语言版本,程序所有应用文字皆引自LANG目录下的语言包文件,独特的套图更换功能,三级物品分类,购物车帖心设计,在国内率先将购物车与商品显示页面完美结合,完

下载
  1. 在店铺页上下文中准确识别当前商家 ID;
  2. 获取该商家发布的所有商品所属的非空、启用、公开的产品分类(product_cat);
  3. 对每个分类调用 WooCommerce 原生 [products] 短代码(支持 store 和 category 参数),并添加语义化标题;
  4. 封装为可复用的短代码,便于在店铺模板或古腾堡区块中灵活调用。

? 完整可用代码(推荐放入子主题的 functions.php)

add_shortcode('wcfm_store_products_by_category', 'wcfm_store_products_by_category');
function wcfm_store_products_by_category($attr) {
    global $WCFM, $WCFMmp, $wp, $post;

    // 步骤1:精准获取当前店铺ID
    $store_id = 0;

    // 场景1:在 /store/{slug} 页面
    if (wcfm_is_store_page()) {
        $wcfm_store_url = get_option('wcfm_store_url', 'store');
        $store_name     = apply_filters('wcfmmp_store_query_var', get_query_var($wcfm_store_url));
        if (!empty($store_name)) {
            $store_user = get_user_by('slug', $store_name);
            $store_id   = $store_user ? $store_user->ID : 0;
        }
    }
    // 场景2:在单个商品页,且作者为已认证供应商
    elseif (is_product() || (is_single() && $post && wcfm_is_vendor($post->post_author))) {
        $store_id = $post->post_author;
    }
    // 场景3:手动传参(兼容性扩展)
    if (isset($attr['id']) && !empty($attr['id'])) {
        $store_id = absint($attr['id']);
    }

    if (!$store_id || !wcfm_is_vendor($store_id)) {
        return '<p class="wcfm-store-category-warning">未识别到有效商家,请检查页面上下文或商家权限。</p>';
    }

    // 步骤2:获取该商家所有已发布商品的唯一分类ID列表(去重+排序)
    $args = array(
        'post_type'      => 'product',
        'post_status'    => 'publish',
        'author'         => $store_id,
        'posts_per_page' => -1,
        'fields'         => 'ids',
    );
    $product_ids = get_posts($args);

    if (empty($product_ids)) {
        return '<p class="wcfm-store-empty">该商家暂无上架商品。</p>';
    }

    $all_terms = array();
    foreach ($product_ids as $pid) {
        $terms = wp_get_post_terms($pid, 'product_cat', array('fields' => 'ids'));
        $all_terms = array_merge($all_terms, $terms);
    }
    $category_ids = array_unique(array_filter($all_terms));

    // 按名称升序排序分类(可选)
    if (!empty($category_ids)) {
        $categories = get_terms(array(
            'taxonomy'   => 'product_cat',
            'include'    => $category_ids,
            'orderby'    => 'name',
            'order'      => 'ASC',
            'hide_empty' => true,
        ));

        if (!is_wp_error($categories) && !empty($categories)) {
            $output = '';
            foreach ($categories as $cat) {
                $output .= '<section class="wcfm-store-category-section" id="cat-' . $cat->term_id . '">';
                $output .= '<h3 class="wcfm-store-category-title">' . esc_html($cat->name) . '</h3>';
                // 使用WooCommerce原生[products]短代码,支持store+category双重过滤
                $output .= do_shortcode('[products category="' . $cat->slug . '" store="' . $store_id . '" columns="4" limit="8"]');
                $output .= '</section>';
            }
            return $output;
        }
    }

    return '<p class="wcfm-store-category-info">暂无分类商品数据。</p>';
}

✅ 使用方式

在商家店铺页编辑器中(Classic Editor 或 Gutenberg 的「自定义HTML」/「短代码」区块),插入:

[wcfm_store_products_by_category]

? 提示:你也可以指定商家ID强制调用,例如:
[wcfm_store_products_by_category id="123"]

⚠ 注意事项与最佳实践

  • 必须使用子主题:避免插件更新时代码丢失;
  • 分类可见性依赖商品状态:仅 publish 状态的商品及其所属分类会被纳入;
  • 性能优化建议:若商家商品量极大(>500),建议配合对象缓存(如 Redis)或增加分页逻辑;
  • 样式控制:输出的

    已预留 CSS 类名(如 wcfm-store-category-section),可在子主题 style.css 中自定义视觉风格;

  • 兼容性验证:本方案兼容 WCFM Marketplace ≥ 3.5.0 与 WooCommerce ≥ 6.0;
  • 调试技巧:临时添加 error_log(print_r($categories, true)); 可排查分类获取失败问题。

通过以上方案,你将获得一个语义清晰、易于维护、符合 WooCommerce 生态规范的分类商品展示模块——既满足买家浏览体验,也提升多商家平台的专业度与转化效率。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

996

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

661

2023.11.14

mongodb和redis哪个读取速度快
mongodb和redis哪个读取速度快

redis 的读取速度比 mongodb 更快。原因包括:1. redis 使用简单的键值存储,而 mongodb 存储 json 格式的数据,需要解析和反序列化。2. redis 使用哈希表快速查找数据,而 mongodb 使用 b-tree 索引。因此,redis 在需要高性能读取操作的应用程序中是一个更好的选择。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

496

2024.04.02

redis怎么做缓存服务器
redis怎么做缓存服务器

redis 作为缓存服务器的答案:redis 是一款开源、高性能、分布式的键值存储,可作为缓存服务器使用。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

407

2024.04.07

redis怎么解决数据一致性
redis怎么解决数据一致性

redis 提供了两种一致性模型,以维护副本数据一致性:强一致性 (sync) 确保写操作仅在复制到所有从节点后才完成;最终一致性 (async) 则在主节点上写操作后认为已完成,牺牲一致性换取性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

404

2024.04.07

mysql和redis怎么保证双写一致性
mysql和redis怎么保证双写一致性

确保 mysql 和 redis 双写一致性的技术包括:1、事务性更新:同时更新 mysql 和 redis,保证一致性;2、主从复制:mysql 主服务器更改同步到 redis 从服务器;3、基于事件的更新:mysql 记录更改并发送到 redis等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

466

2024.04.07

redis缓存一般存些什么数据
redis缓存一般存些什么数据

redis缓存中存储的数据类型包括:字符串、哈希、列表、集合、有序集合、位图、地理空间数据和hyperloglog。这些数据类型适用于存储各种数据,从简单信息到复杂对象和地理位置。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

418

2024.04.07

redis的8种数据类型有哪些
redis的8种数据类型有哪些

redis 提供 8 种数据类型:字符串(文本、数字、二进制)、哈希(键值对)、列表(有序集合)、集合(无序唯一元素)、有序集合(按分数排序)、地理空间(地理位置)、hyperloglog(估计大数据基数)和位图(位序列存储)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

444

2024.04.07

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

660

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号