0

0

定制WooCommerce预订显示:将结束日期替换为预订时长

心靈之曲

心靈之曲

发布时间:2025-11-28 13:15:21

|

237人浏览过

|

来源于php中文网

原创

定制WooCommerce预订显示:将结束日期替换为预订时长

本教程旨在解决woocommerce bookings插件中默认显示预订开始日期和结束日期,而非预订时长的问题。我们将探讨如何通过覆盖woocommerce bookings模板文件这一核心方法,在购物车、我的账户页面及订单邮件中,将预订的结束日期替换为更直观的预订时长,从而提升用户和管理员的体验,并提供具体的实现思路和最佳实践。

引言:优化WooCommerce预订日期显示体验

在WooCommerce Bookings插件的实际应用中,尤其当产品以天为单位进行预订时,系统默认在订单摘要、我的账户页面以及邮件通知中显示预订的“开始日期”和“结束日期”。然而,对于许多用户和管理员而言,直接显示“开始日期”和“预订时长”更为直观和实用,能够有效避免混淆。例如,客户预订了3天,看到“开始日期:2023年10月26日,结束日期:2023年10月28日”可能不如“开始日期:2023年10月26日,预订时长:3天”清晰明了。本教程将指导您如何通过WooCommerce推荐的方式,实现这一显示优化。

理解WooCommerce预订日期显示机制与现有尝试

WooCommerce Bookings插件在不同的页面和通知中,通过其内部逻辑和模板文件来渲染预订产品的详细信息。默认情况下,它倾向于展示完整的日期范围。

有开发者尝试通过WordPress的过滤器(如wc_bookings_summary_list_date)来干预日期显示。例如,以下代码可以隐藏结束日期,只显示开始日期:

function modify_summary_date_20170821( $booking_date, $booking_start, $booking_end ) {
    echo 'Ankunft: '; // 可自定义前缀,如“Arrival:”
    return date_i18n( wc_date_format(), $booking_start );
}       
add_filter( 'wc_bookings_summary_list_date', 'modify_summary_date_20170821', 10, 3 );

这段代码确实能够阻止结束日期被显示,并允许自定义开始日期的前缀。然而,这个过滤器仅提供了$booking_date(通常是开始日期)、$booking_start和$booking_end作为参数。它无法直接提供预订时长的信息,也无法在现有参数的基础上轻松计算并插入时长,因为其设计目的主要是修改日期字符串本身,而非添加新的数据字段或改变整体结构。因此,要实现将结束日期替换为预订时长,我们需要更深层次的定制方法。

核心解决方案:通过模板覆盖定制显示

WooCommerce及其扩展插件(包括Bookings)都提供了强大的模板覆盖机制,允许开发者在不修改插件核心文件的情况下,自定义插件的输出内容。这是实现将结束日期替换为预订时长的最推荐和最灵活的方法。

为什么选择模板覆盖?

  1. 最大灵活性: 直接控制HTML结构和PHP逻辑,可以精确地调整显示内容和样式。
  2. 未来兼容性: 您的修改位于子主题中,插件更新时不会被覆盖。
  3. 直接访问数据: 在模板文件中,您可以直接访问到完整的预订对象(WC_Booking),从而获取其所有属性,包括开始日期、结束日期、时长和时长单位等。

识别相关模板文件

WooCommerce Bookings插件在多个地方显示预订详情,您可能需要根据实际需求修改一个或多个模板文件:

  • 我的账户页面: woocommerce-bookings/templates/myaccount/bookings.php 或其包含的其他模板。
  • 订单详情页(后台及前端): woocommerce-bookings/templates/order/booking-details.php。
  • 邮件通知: woocommerce-bookings/templates/emails/customer-booking-details.php (发给客户的邮件) 和 woocommerce-bookings/templates/emails/admin-new-booking.php (发给管理员的邮件)。
  • 购物车/结账页面: 某些情况下可能涉及 woocommerce-bookings/templates/cart/cart-item-booking.php 或类似文件。

您可以在 wp-content/plugins/woocommerce-bookings/templates/ 目录下找到所有原始模板文件。

PixVerse
PixVerse

PixVerse是一款强大的AI视频生成工具,可以轻松地将多种输入转化为令人惊叹的视频。

下载

模板覆盖步骤

  1. 创建子主题(如果尚未创建): 模板覆盖必须在子主题中进行,以确保插件更新后您的修改不会丢失。
  2. 复制模板文件:
    • 在您的子主题目录中,创建一个名为 woocommerce-bookings 的文件夹。
    • 将您需要修改的原始模板文件(例如,myaccount/bookings.php)从 wp-content/plugins/woocommerce-bookings/templates/ 复制到您的子主题的 woocommerce-bookings/ 文件夹中,并保持原有的子目录结构。
      • 例如,如果您要修改 myaccount/bookings.php,则复制到 your-child-theme/woocommerce-bookings/myaccount/bookings.php。
  3. 修改模板文件以显示时长:
    • 打开复制到子主题的模板文件。
    • 在这些模板中,您会发现用于显示预订详情的代码,通常会有一个 $booking 变量,它是一个 WC_Booking 类的实例。
    • 找到显示开始日期和结束日期的代码段。例如,您可能会看到类似 echo $booking->get_start_date(); 和 echo $booking->get_end_date(); 的代码。
    • 将显示结束日期的代码替换为显示预订时长的代码。WC_Booking 对象提供了获取时长的方法。

以下是一个概念性的代码示例,展示如何在模板中获取并显示预订时长:

get_start_date( 'timestamp' ) );

    // 获取预订时长和单位
    $duration = $booking->get_duration();
    $duration_unit = $booking->get_duration_unit(); // 例如 'day', 'hour', 'minute'

    // 根据单位进行本地化显示,例如将 'day' 显示为 '天'
    $translated_duration_unit = '';
    switch ( $duration_unit ) {
        case 'day':
            $translated_duration_unit = __( '天', 'your-text-domain' ); // 替换 'your-text-domain' 为您主题或插件的文本域
            break;
        case 'hour':
            $translated_duration_unit = __( '小时', 'your-text-domain' );
            break;
        case 'minute':
            $translated_duration_unit = __( '分钟', 'your-text-domain' );
            break;
        default:
            $translated_duration_unit = $duration_unit;
            break;
    }

    // 输出开始日期和预订时长
    echo '

开始日期: ' . esc_html( $start_date_formatted ) . '

'; echo '

预订时长: ' . esc_html( $duration ) . ' ' . esc_html( $translated_duration_unit ) . '

'; // 您可以根据需要移除或注释掉显示结束日期的原有代码 // 例如: // echo '

结束日期: ' . date_i18n( wc_date_format(), $booking->get_end_date( 'timestamp' ) ) . '

'; } ?>

**

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2593

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1620

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1508

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1417

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1447

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.16

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 7.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

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

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