0

0

WooCommerce教程:根据产品分类显示预计交货时间,并处理库存状态

聖光之護

聖光之護

发布时间:2025-09-07 22:30:30

|

206人浏览过

|

来源于php中文网

原创

woocommerce教程:根据产品分类显示预计交货时间,并处理库存状态

本文旨在帮助WooCommerce开发者根据产品所属的特定分类(taxonomy)来显示预计交货时间,并提供代码示例,同时涵盖了如何根据当前时间动态调整交货日期、自定义显示信息以及在产品缺货时隐藏交货提示的方法。通过学习本文,你将能够灵活地控制WooCommerce产品页面的交货信息展示,提升用户体验。

根据产品分类显示预计交货时间

在WooCommerce中,经常需要根据产品的不同属性来展示不同的信息。例如,针对特定分类的产品,显示预计的交货时间。以下代码展示了如何根据产品所属的自定义分类(taxonomy)来显示交货时间信息。

add_action( 'woocommerce_before_add_to_cart_form', 'delivery_estimate' );

function delivery_estimate() {

   global $product;

   // 检查产品类型是否为 'product'
   if ( 'product' == $product->post_type ) {

       // 获取产品的自定义分类 'available_now'
       $terms = wp_get_post_terms( $product->id, 'available_now' );

       // 错误处理
       if ( $terms instanceof WP_Error ) {
           // 在这里记录错误信息,或者进行其他处理
           error_log("Error getting terms: " . $terms->get_error_message());

       } elseif ( ! empty( $terms ) ) {

           $term = $terms[ 0 ]; // 假设产品只有一个 'available_now' 分类

           // 检查分类的别名 (slug) 是否为 'ready-to-ship'
           if ( 'ready-to-ship' == $term->slug ) {

               date_default_timezone_set( 'Europe/Tallinn' );

               // 如果是周五/周六/周日,则交货时间为下周一
               if ( date( 'N' ) >= 5 ) {
                  $del_day = date( "l jS F", strtotime( "next tuesday" ) );
                  $order_by = "Monday";
               }

               // 如果是周一/周四下午4点后,则交货时间为后天
               elseif ( date( 'H' ) >= 16 ) {
                  $del_day = date( "l jS F", strtotime( "tomorrow + 1 day" ) );
                  $order_by = "tomorrow";
               }

               // 如果是周一/周四下午4点前,则交货时间为明天
               else {
                  $del_day = date( "l jS F", strtotime( "tomorrow" ) );
                  $order_by = "today";
               }

               // 获取剩余时间,假设截止时间是每天的16:00
               $now = time();
               $end_of_day = strtotime('today 16:00');
               $hours_left = round(($end_of_day - $now) / 3600);

               // 构建HTML消息
               $html = "
Ready for delivery between " . date("jS F", strtotime($del_day)) . " & " . date("jS F", strtotime($del_day . " + 3 days")) . " when you order within {$hours_left} hours.
"; echo $html; } // endif } // endif }

代码解释:

  1. add_action( 'woocommerce_before_add_to_cart_form', 'delivery_estimate' );: 将 delivery_estimate 函数挂载到 woocommerce_before_add_to_cart_form 这个 action hook 上,以便在添加到购物车表单之前执行该函数。
  2. global $product;: 获取全局的 $product 对象,该对象包含了当前产品的信息。
  3. if ( 'product' == $product->post_type ): 确认当前页面展示的是产品页面,避免在其他页面执行。
  4. $terms = wp_get_post_terms( $product->id, 'available_now' );: 获取当前产品 available_now 这个自定义分类的所有信息。请将 available_now 替换成你实际使用的分类名。
  5. if ( $terms instanceof WP_Error ): 检查获取分类信息时是否发生错误。如果发生错误,可以记录错误日志或者进行其他处理。
  6. elseif ( ! empty( $terms ) ): 确认分类信息不为空,即产品确实属于 available_now 这个分类。
  7. $term = $terms[ 0 ];: 获取第一个分类信息。通常一个产品只会属于一个 available_now 分类,所以取第一个即可。
  8. if ( 'ready-to-ship' == $term->slug ): 检查分类的别名(slug)是否为 ready-to-ship。 请将 ready-to-ship 替换成你实际使用的分类别名。
  9. 时间计算部分: 根据当前日期和时间计算预计的交货日期。
  10. $html = ...: 构建HTML消息,显示预计交货时间和剩余时间。
  11. echo $html;: 输出HTML消息,将其显示在产品页面上。

注意事项:

  • 请将代码中的 'available_now' 替换成你实际使用的自定义分类名。
  • 请将代码中的 'ready-to-ship' 替换成你实际使用的分类别名。
  • date_default_timezone_set( 'Europe/Tallinn' ); 设置时区,请根据实际情况修改。
  • 可以根据实际需求修改HTML消息的内容和样式。
  • 错误处理部分可以根据实际需求进行更详细的处理,例如记录错误日志、发送邮件通知等。

处理产品库存状态

除了根据产品分类显示交货时间,还需要考虑产品库存状态。如果产品缺货,则不应该显示交货时间信息。以下代码展示了如何在产品缺货时隐藏交货时间提示。

Groq
Groq

GroqChat是一个全新的AI聊天机器人平台,支持多种大模型语言,可以免费在线使用。

下载
add_action( 'woocommerce_before_add_to_cart_form', 'delivery_estimate' );

function delivery_estimate() {

   global $product;

   // 检查产品类型是否为 'product'
   if ( 'product' == $product->post_type ) {

        // 检查产品是否在库存中
        if ( $product->is_in_stock() ) {

           // 获取产品的自定义分类 'available_now'
           $terms = wp_get_post_terms( $product->id, 'available_now' );

           // 错误处理
           if ( $terms instanceof WP_Error ) {
               // 在这里记录错误信息,或者进行其他处理
               error_log("Error getting terms: " . $terms->get_error_message());

           } elseif ( ! empty( $terms ) ) {

               $term = $terms[ 0 ]; // 假设产品只有一个 'available_now' 分类

               // 检查分类的别名 (slug) 是否为 'ready-to-ship'
               if ( 'ready-to-ship' == $term->slug ) {

                   date_default_timezone_set( 'Europe/Tallinn' );

                   // 如果是周五/周六/周日,则交货时间为下周一
                   if ( date( 'N' ) >= 5 ) {
                      $del_day = date( "l jS F", strtotime( "next tuesday" ) );
                      $order_by = "Monday";
                   }

                   // 如果是周一/周四下午4点后,则交货时间为后天
                   elseif ( date( 'H' ) >= 16 ) {
                      $del_day = date( "l jS F", strtotime( "tomorrow + 1 day" ) );
                      $order_by = "tomorrow";
                   }

                   // 如果是周一/周四下午4点前,则交货时间为明天
                   else {
                      $del_day = date( "l jS F", strtotime( "tomorrow" ) );
                      $order_by = "today";
                   }

                   // 获取剩余时间,假设截止时间是每天的16:00
                   $now = time();
                   $end_of_day = strtotime('today 16:00');
                   $hours_left = round(($end_of_day - $now) / 3600);

                   // 构建HTML消息
                   $html = "
Ready for delivery between " . date("jS F", strtotime($del_day)) . " & " . date("jS F", strtotime($del_day . " + 3 days")) . " when you order within {$hours_left} hours.
"; echo $html; } // endif } // endif } // endif } }

代码解释:

  • if ( $product->is_in_stock() ): 使用 $product->is_in_stock() 函数检查产品是否在库存中。只有当产品在库存中时,才会显示交货时间信息。

总结:

通过以上代码示例,你可以在WooCommerce中根据产品分类和库存状态动态显示预计交货时间。这可以帮助你更好地向客户展示产品信息,提高用户体验,并最终促进销售。请务必根据你的实际需求修改代码,并进行充分的测试。

相关专题

更多
html版权符号
html版权符号

html版权符号是“©”,可以在html源文件中直接输入或者从word中复制粘贴过来,php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

594

2023.06.14

html在线编辑器
html在线编辑器

html在线编辑器是用于在线编辑的工具,编辑的内容是基于HTML的文档。它经常被应用于留言板留言、论坛发贴、Blog编写日志或等需要用户输入普通HTML的地方,是Web应用的常用模块之一。php中文网为大家带来了html在线编辑器的相关教程、以及相关文章等内容,供大家免费下载使用。

638

2023.06.21

html网页制作
html网页制作

html网页制作是指使用超文本标记语言来设计和创建网页的过程,html是一种标记语言,它使用标记来描述文档结构和语义,并定义了网页中的各种元素和内容的呈现方式。本专题为大家提供html网页制作的相关的文章、下载、课程内容,供大家免费下载体验。

460

2023.07.31

html空格
html空格

html空格是一种用于在网页中添加间隔和对齐文本的特殊字符,被用于在网页中插入额外的空间,以改变元素之间的排列和对齐方式。本专题为大家提供html空格的相关的文章、下载、课程内容,供大家免费下载体验。

242

2023.08.01

html是什么
html是什么

HTML是一种标准标记语言,用于创建和呈现网页的结构和内容,是互联网发展的基石,为网页开发提供了丰富的功能和灵活性。本专题为大家提供html相关的各种文章、以及下载和课程。

2861

2023.08.11

html字体大小怎么设置
html字体大小怎么设置

在网页设计中,字体大小的选择是至关重要的。合理的字体大小不仅可以提升网页的可读性,还能够影响用户对网页整体布局的感知。php中文网将介绍一些常用的方法和技巧,帮助您在HTML中设置合适的字体大小。

501

2023.08.11

html转txt
html转txt

html转txt的方法有使用文本编辑器、使用在线转换工具和使用Python编程。本专题为大家提供html转txt相关的文章、下载、课程内容,供大家免费下载体验。

306

2023.08.31

html文本框代码怎么写
html文本框代码怎么写

html文本框代码:1、单行文本框【<input type="text" style="height:..;width:..;" />】;2、多行文本框【textarea style=";height:;"></textare】。

419

2023.09.01

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.7万人学习

AngularJS教程
AngularJS教程

共24课时 | 2.2万人学习

CSS教程
CSS教程

共754课时 | 17.4万人学习

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

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