导读:本期聚焦于小伙伴创作的《如何在WooCommerce管理订单详情页的订单项目中显示产品元数据》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《如何在WooCommerce管理订单详情页的订单项目中显示产品元数据》有用,将其分享出去将是对创作者最好的鼓励。

在WooCommerce的默认订单管理页面中,订单项目区域仅展示产品名称、数量、单价等基础信息,产品的自定义元数据不会直接显示,这给需要核对产品附加信息的商家带来了不便。通过添加自定义代码,我们可以让产品元数据直接展示在订单项目下方,无需额外跳转查看。

如何在WooCommerce管理订单详情页的订单项目中显示产品元数据

实现原理

WooCommerce提供了woocommerce_order_item_meta_end钩子,该钩子会在订单详情页每个订单项目的元数据区域末尾执行,我们可以在这个钩子的回调函数中获取当前订单项目的产品对象,再提取产品的自定义元数据并输出到页面上。

基础实现代码

将以下代码添加到当前主题的functions.php文件中,即可显示产品的所有自定义元数据:

add_action('woocommerce_order_item_meta_end', 'display_product_meta_in_order_items', 10, 3);
function display_product_meta_in_order_items($item_id, $item, $order) {
    // 获取订单项目对应的产品对象
    $product = $item->get_product();
    if (!$product) {
        return;
    }
    // 获取产品的所有自定义元数据
    $meta_data = $product->get_meta_data();
    if (empty($meta_data)) {
        return;
    }
    echo '<div class="order-item-product-meta">';
    echo '<p><strong>产品附加信息:</strong></p>';
    echo '<ul>';
    foreach ($meta_data as $meta) {
        $data = $meta->get_data();
        // 跳过系统默认的元数据,仅展示自定义字段
        if (strpos($data['key'], '_') === 0) {
            continue;
        }
        echo '<li>' . esc_html($data['key']) . ':' . esc_html($data['value']) . '</li>';
    }
    echo '</ul>';
    echo '</div>';
}

指定显示特定元数据

如果只需要显示某几个特定的产品元数据,而不是全部自定义字段,可以修改代码中的循环部分,指定要展示的元数据键名:

add_action('woocommerce_order_item_meta_end', 'display_specific_product_meta_in_order_items', 10, 3);
function display_specific_product_meta_in_order_items($item_id, $item, $order) {
    $product = $item->get_product();
    if (!$product) {
        return;
    }
    // 指定要显示的元数据键名
    $target_meta_keys = array('product_color', 'product_size', 'product_material');
    $has_meta = false;
    echo '<div class="order-item-product-meta">';
    echo '<p><strong>产品规格:</strong></p>';
    echo '<ul>';
    foreach ($target_meta_keys as $meta_key) {
        $meta_value = $product->get_meta($meta_key);
        if (!empty($meta_value)) {
            $has_meta = true;
            echo '<li>' . esc_html($meta_key) . ':' . esc_html($meta_value) . '</li>';
        }
    }
    echo '</ul>';
    if (!$has_meta) {
        echo '<p>暂无指定规格信息</p>';
    }
    echo '</div>';
}

样式调整建议

默认输出的元数据可能没有合适的样式,可以在主题的样式文件中添加以下CSS,让显示效果更美观:

.order-item-product-meta {
    margin-top: 10px;
    padding: 8px;
    background-color: #f9f9f9;
    border-left: 3px solid #007cba;
    font-size: 14px;
}
.order-item-product-meta ul {
    margin: 5px 0 0 0;
    padding-left: 20px;
}
.order-item-product-meta li {
    margin-bottom: 3px;
}

注意事项

  • 修改主题文件前建议先备份,避免代码错误导致网站异常。
  • 如果使用子主题,代码应添加到子主题的functions.php中,避免主题更新后代码丢失。
  • 部分产品元数据可能是序列化数据,直接输出会显示乱码,这类数据需要先反序列化再处理。
  • 如果产品元数据包含敏感信息,需要确认是否适合在订单详情页展示,避免信息泄露。

WooCommerce订单详情页产品元数据WordPress钩子订单项目修改时间:2026-06-05 16:17:56

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。