WooCommerce结账页:根据配送日期动态添加额外费用(含日期选择器集成)

WooCommerce结账页:根据配送日期动态添加额外费用(含日期选择器集成)

本教程详细指导如何在woocommerce结账页面集成xdsoft datetimepicker,并根据用户选择的配送日期动态收取额外费用。文章涵盖了自定义日期字段的添加、日期选择器的配置、基于日期差异计算和应用费用的php逻辑,以及如何将配送日期保存并显示在订单详情和邮件中,确保结账流程的灵活性和业务规则的准确执行。

在WooCommerce商店中,有时需要根据客户选择的配送日期来调整订单费用,例如为当日或次日配送收取额外加急费。本教程将引导您完成在WooCommerce结账页面实现这一功能的完整步骤,包括添加自定义日期选择器、动态计算费用以及将选择的日期保存到订单信息中。

一、添加自定义配送日期选择器

首先,我们需要在WooCommerce结账页面添加一个用于选择配送日期的字段,并对其进行基础验证。

 'text',        'class'       => array('form-row-wide'),        'id'          => 'datepicker', // 用于JS选择器        'required'    => true,        'label'       => __('Select Delivery Date', 'your-text-domain'),        'placeholder' => __('Click to select date', 'your-text-domain'),    ));}add_action( 'woocommerce_after_order_notes', 'custom_delivery_date_field' );/** * 验证配送日期字段是否已选择 */function validate_delivery_date_field() {    if ( isset( $_POST['delivery_date'] ) && empty( $_POST['delivery_date'] ) ) {        wc_add_notice( __( 'Please select the Delivery Date', 'your-text-domain' ), 'error' );    }}add_action( 'woocommerce_checkout_process', 'validate_delivery_date_field' );?>

代码说明:

custom_delivery_date_field 函数通过 woocommerce_form_field 创建一个类型为 text 的输入字段,其 id 设置为 datepicker,方便后续JavaScript进行初始化。woocommerce_after_order_notes 钩子确保该字段显示在订单备注区域下方。validate_delivery_date_field 函数在结账处理时检查 delivery_date 字段是否为空,若为空则添加一个错误通知。

二、集成并配置xdsoft DateTimePicker

为了提供友好的日期选择体验,我们将集成 xdsoft DateTimePicker。此步骤包括引入必要的JavaScript库和初始化日期选择器,并配置其在日期或时间选择后触发WooCommerce结账页面的更新。

                        jQuery(document).ready(function($) {            jQuery.datetimepicker.setLocale('en'); // 设置语言环境            // 获取当前时间,并向上取整到最近的30分钟,确保可选时间从当前时间之后开始            var currentDate = new Date();            var minutes = currentDate.getMinutes();            var m = (Math.ceil(minutes / 30) * 30) % 60;            currentDate.setMinutes(m);            jQuery('#datepicker').datetimepicker({                // beforeShowDay: $.datepicker.noWeekends, // 禁用周末,如果需要可以启用                format: 'Y/m/d H:i:s', // 日期时间格式                minDate: 0,            // 最小可选日期为今天                minTime: '8:00',       // 最小可选时间                step: 30,              // 时间步长为30分钟                allowTimes: [          // 允许选择的时间段                    '09:00', '09:30', '10:00', '10:30', '11:00', '11:30', '12:00', '12:30',                    '13:00', '13:30', '14:00', '14:30', '15:00', '15:30', '16:00', '16:30', '17:00'                ],                onSelectDate: function(ct, $i) {                    // 当选择日期时,触发WooCommerce结账页面的更新,以便重新计算费用                    jQuery('body').trigger('update_checkout');                },                onSelectTime: function(ct, $i) {                    // 当选择时间时,触发WooCommerce结账页面的更新                    jQuery('body').trigger('update_checkout');                }            });        });        

代码说明:

load_and_init_datetimepicker 函数通过 woocommerce_after_checkout_form 钩子在结账表单底部加载JavaScript和CSS库。jQuery.datetimepicker.setLocale(‘en’) 设置日期选择器的语言。minDate: 0 确保用户不能选择过去的日期。onSelectDate 和 onSelectTime 回调函数是关键,它们在用户选择日期或时间后,通过 jQuery(‘body’).trigger(‘update_checkout’) 触发WooCommerce结账页面的AJAX更新,从而实时重新计算订单费用。

三、实现基于配送日期的额外费用逻辑

这一部分是核心,我们将使用 woocommerce_cart_calculate_fees 钩子来检查用户选择的配送日期,并根据规则动态添加或移除额外费用。

cart->add_fee( __( 'Fast delivery charge', 'your-text-domain' ), $fee_amount, true, 'standard' );        } else {            // 如果不是今天或明天,确保移除可能存在的加急费用            $fees = WC()->cart->get_fees();            foreach ( $fees as $key => $fee ) {                if ( $fee->name === __( 'Fast delivery charge', 'your-text-domain' ) ) {                    unset( $fees[$key] );                    // 重新设置购物车费用,以移除特定费用                    WC()->cart->fees_api()->set_fees( $fees );                    break; // 找到并移除后即可退出循环                }            }        }    } else {        // 如果没有选择配送日期,也移除可能存在的加急费用        $fees = WC()->cart->get_fees();        foreach ( $fees as $key => $fee ) {            if ( $fee->name === __( 'Fast delivery charge', 'your-text-domain' ) ) {                unset( $fees[$key] );                WC()->cart->fees_api()->set_fees( $fees );                break;            }        }    }}add_action( 'woocommerce_cart_calculate_fees','wc_add_delivery_surcharge' );?>

代码说明:

wc_add_delivery_surcharge 函数挂载到 woocommerce_cart_calculate_fees 钩子,确保在购物车费用计算时执行。通过 parse_str( $_POST[‘post_data’], $post_data ) 获取结账表单提交的数据,其中包含 delivery_date。将选定日期和当前日期转换为时间戳,计算它们之间的天数差异。如果差异为 0(今天)或 1(明天),则使用 WC()->cart->add_fee() 添加名为“Fast delivery charge”的额外费用。关键的移除逻辑: 如果用户选择了非加急日期,或者没有选择日期,代码会遍历当前购物车中的所有费用,如果找到名为“Fast delivery charge”的费用,则将其移除。这确保了费用的动态性和准确性。

四、保存与显示配送日期信息

为了在订单管理和通知中查看配送日期,我们需要将其保存到订单元数据中,并在后台订单详情页和客户邮件中显示。

get_meta( '_delivery_date' );    if ( $delivery_date ) {        echo '

' . __( 'Delivery Date', 'your-text-domain' ) . ': ' . esc_html( $delivery_date ) . '

'; }}add_action( 'woocommerce_admin_order_data_after_billing_address', 'display_delivery_date_in_admin_order', 10, 1 );/** * 在WooCommerce订单邮件中显示配送日期 * * @param WC_Order $order 订单对象 * @param bool $sent_to_admin 是否发送给管理员 * @param bool $plain_text 是否为纯文本邮件 * @param WC_Email $email 邮件对象 */function display_delivery_date_in_emails( $order, $sent_to_admin, $plain_text, $email ) { $delivery_date = $order->get_meta( '_delivery_date' ); if ( $delivery_date ) { echo '

' . __( 'Delivery Date', 'your-text-domain' ) . ': ' . esc_html( $delivery_date ) . '

'; }}add_action( 'woocommerce_email_after_order_table', 'display_delivery_date_in_emails', 20, 4 );?>

代码说明:

save_delivery_date_field_to_order_meta 函数使用 woocommerce_checkout_update_order_meta 钩子将 delivery_date 的值保存为订单的元数据(_delivery_date)。display_delivery_date_in_admin_order 函数使用 woocommerce_admin_order_data_after_billing_address 钩子在WooCommerce后台订单编辑页面的账单地址下方显示配送日期。display_delivery_date_in_emails 函数使用 woocommerce_email_after_order_table 钩子在所有WooCommerce订单邮件(包括客户和管理员邮件)的订单表格下方显示配送日期。

五、注意事项与总结

代码放置位置: 所有上述PHP代码应放置在您主题的 functions.php 文件中,或创建一个自定义插件来管理这些功能。推荐使用自定义插件,以确保主题更新不会覆盖您的定制代码。文本域: 在代码中使用了 ‘your-text-domain’ 作为文本域,请根据您的主题或插件实际使用的文本域进行替换,以便进行国际化。费用金额与名称: wc_add_delivery_surcharge 函数中的 $fee_amount 和费用名称 ‘Fast delivery charge’ 可以根据您的业务需求进行调整。日期选择器配置: load_and_init_datetimepicker 函数中的 minDate、minTime、step 和 allowTimes 等选项可以根据您的配送策略进行灵活配置。例如,如果您不希望周末配送,可以启用 beforeShowDay: $.datepicker.noWeekends。AJAX更新: onSelectDate 和 onSelectTime 中触发 jQuery(‘body’).trigger(‘update_checkout’) 是实现费用动态计算的关键。这会向服务器发送AJAX请求,重新计算购物车总额和费用,并更新结账页面显示。

通过以上步骤,您已经成功地在WooCommerce结账页面实现了一个功能完善的配送日期选择器,并能够根据用户的选择动态地添加或移除额外费用,同时将配送日期保存并显示在订单的各个环节中。这不仅提升了用户体验,也为您的业务提供了更大的灵活性。

以上就是WooCommerce结账页:根据配送日期动态添加额外费用(含日期选择器集成)的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1329115.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月12日 15:21:05
下一篇 2025年12月12日 15:21:12

相关推荐

  • PHP反射机制:获取函数或方法参数类型列表的实用指南

    本文将深入探讨php反射(reflection)机制,重点介绍如何利用reflectionmethod类动态获取函数或方法的参数类型列表。通过具体的代码示例,我们将演示如何识别参数的类名、内置类型或是否无类型声明,这对于构建依赖注入、api文档生成或运行时类型检查等高级功能至关重要。 PHP的反射(…

    2025年12月13日
    000
  • 在Symfony中对加密字段应用UniqueEntity约束的策略

    在symfony框架中,直接对加密字段使用`@uniqueentity`约束通常会失效,因为验证发生在数据加密之前,导致无法正确比对数据库中已加密的值。本文将深入探讨这一挑战,并提供两种有效的解决方案:一是通过存储字段的哈希值并对其进行唯一性检查,二是通过自定义repository方法,在验证过程中…

    2025年12月13日
    000
  • 解决 Ubuntu 20 WSL 环境下 PHP 脚本终端无输出问题指南

    本文旨在解决在 ubuntu 20 wsl 环境下运行 php 脚本时终端无输出的常见问题。文章将详细指导用户验证 php cli 安装、正确使用脚本执行命令,并介绍通过添加 shebang 行来直接执行 php 脚本的方法。通过这些步骤,用户可以有效地调试并确保 php 脚本在终端中正常显示输出。…

    2025年12月13日
    000
  • Laravel中定义用户与事件的多层级关联:三种实现方式

    本文详细介绍了在Laravel框架中如何定义和管理一个复杂的多层级关联关系,即用户通过所属的多个组织来关联到事件。文章通过定义`belongsToMany`、`hasMany`和`belongsTo`等Eloquent关系,并提供了三种不同的数据检索方法:迭代式获取、用户模型内封装为集合以及用户模型…

    2025年12月13日
    000
  • PHP表单验证中的数据类型错误:trim()函数与$_POST数组的正确使用

    本文深入探讨了php表单处理中常见的typeerror: trim(): argument #1 ($string) must be of type string, array given错误。该错误通常源于对$_post超全局数组的不正确访问语法,例如误用赋值运算符=代替数组访问方括号[]。教程将…

    2025年12月13日
    000
  • 创建自定义PHP页面并安全访问WooCommerce数据教程

    本文将指导您如何在wordpress环境中创建一个完全独立的php页面,并有效访问woocommerce数据。核心在于理解并正确引导wordpress环境,而非尝试直接连接数据库。通过引入wordpress核心加载文件,您可以利用woocommerce提供的强大api,安全、高效地获取和展示产品信息…

    2025年12月13日
    000
  • PHP 表单中实现邮件地址验证与特定顶级域名黑名单管理

    本文详细介绍了如何在 php 在线表单中实现健壮的邮件地址验证,并在此基础上添加特定顶级域名(如 .de 和 .it)的黑名单功能。通过结合使用 `filter_var` 进行基础格式验证和 `preg_match` 进行自定义域名过滤,开发者可以有效提升表单数据的质量和安全性,防止来自不受欢迎域名…

    2025年12月13日
    000
  • CodeIgniter并发注册:利用数据库表锁解决邮箱重复问题

    在CodeIgniter中,面对高并发注册场景下,即使进行服务端验证,仍可能出现多个用户使用相同邮箱注册成功的问题。本文将介绍一种不依赖数据库唯一约束,而是通过在数据检查和插入操作前后使用数据库表锁的策略,有效防止并发注册导致的邮箱重复,确保数据一致性。 解决并发注册邮箱重复的挑战 在Web应用中,…

    2025年12月13日
    000
  • Magento 2 观察者中安全更新产品属性与库存状态的最佳实践

    在magento 2中,通过观察者(observer)更新产品属性,尤其是库存状态,常因事件选择不当导致无限循环。本文将详细探讨在`catalog_product_save_after`事件中尝试保存产品所引发的问题,并推荐使用`catalog_product_save_before`事件作为解决方…

    2025年12月13日
    000
  • Livewire 文件上传验证首次失败:深入解析与解决方案

    本文旨在深入探讨 livewire 文件上传验证首次失败但二次提交成功这一常见问题。我们将分析其背后的核心原因,包括 livewire 异步文件上传机制与验证时机冲突、开发服务器限制,并提供具体的调试方法、代码示例及最佳实践,帮助开发者有效解决此类问题,确保文件上传功能的稳定可靠。 在 Livewi…

    2025年12月13日
    000
  • WooCommerce购物车中始终显示所有交叉销售商品的教程

    本教程详细介绍了如何在woocommerce购物车页面中,通过自定义`woocommerce_cart_crosssell_ids`过滤器,实现始终显示所有关联的交叉销售商品,即使这些商品已存在于购物车中。我们将通过php代码示例,指导开发者如何覆盖woocommerce的默认行为,以提供更全面的商…

    2025年12月13日
    000
  • PHP集成Walmart Returns API指南:认证、请求与常见错误解决

    本教程旨在指导开发者使用php curl集成walmart退货api。文章详细阐述了通过oauth 2.0客户端凭证流获取访问令牌的认证过程,以及如何利用该令牌向退货api端点发起get请求。教程重点纠正了导致`invalid_request`错误的常见问题,特别是强调`wm_qos.correla…

    2025年12月13日
    000
  • 理解 PHP 魔术方法 __isset 的必要性与实践

    在 php 中使用 `__get` 和 `__set` 魔术方法处理动态属性时,`__isset` 魔术方法的实现对于维护属性行为的一致性至关重要。尽管其可能引入额外的性能开销,但它确保了 `isset()` 和 `empty()` 等操作的正确性,并遵循了静态分析工具推荐的最佳实践,从而提升了代码…

    2025年12月13日
    000
  • MySQL JSON 类型字段在 PDO 中使用时的语法错误与解决方案

    本文深入探讨了在使用 PHP PDO 向 MySQL JSON 类型字段执行 `INSERT` 和 `UPDATE` 操作时常见的语法错误。核心问题在于 `VALUES` 子句中占位符的错误使用以及 `JSON_ARRAY_INSERT` 函数对插入值格式的特殊要求。教程将提供详细的错误分析、修正后…

    2025年12月13日
    000
  • 在 Laravel 应用中实现可靠的移动设备访问控制与网站拦截

    本文旨在解决在 laravel 应用中,通过 javascript 进行移动设备检测并拦截访问时,用户切换到“桌面站点”模式导致拦截失效的问题。我们将探讨客户端检测的局限性,并详细介绍如何利用服务器端 http user-agent 头信息,结合 laravel 框架的中间件机制,实现更健壮、不易被…

    2025年12月13日
    000
  • PHP获取相机快门次数:解析EXIF中的MakerNote数据

    获取数码照片的快门次数通常无法通过PHP标准函数`exif_read_data()`直接获得,因为快门次数这类信息常存储在相机制造商专有的`MakerNote`区域。本文将深入探讨`MakerNote`的特性,解释为何标准EXIF解析器难以读取,并提供使用专业工具如ExifTool配合PHP获取快门…

    2025年12月13日
    000
  • 如何使用正则表达式精确验证产品代码格式

    本文详细介绍了如何构建一个精确的正则表达式,用于验证特定格式的产品代码,即前两位为大写字母,后四位为数字。文章分析了常见的正则编写错误,例如不当使用量词和字符转义,并提供了正确的表达式及其变体,包括[0-9]和d的互换,以及在不同编程语言(如PHP)中使用时的注意事项,旨在帮助读者掌握正则表达式的正…

    2025年12月13日
    000
  • PHP中利用Carbon库高效获取月份的周起始与结束日期

    本文将指导您如何在PHP中高效地获取指定月份或日期所在周的起始与结束日期。我们将重点介绍并推荐使用功能强大的`nesbot/carbon`库,它极大地简化了日期和时间的操作。通过详细的安装步骤、基础用法和核心功能示例,您将学会如何利用Carbon库轻松处理复杂的日期计算,包括遍历月份并获取其包含的所…

    2025年12月13日
    000
  • Symfony异步邮件发送策略:从Messenger误用到Cron调度实现

    本文探讨了在Symfony应用中实现异步邮件发送时,将服务直接路由到Messenger传输层可能导致邮件立即发送而非异步处理的问题。针对此场景,文章提供了一种基于数据库存储邮件任务、结合Symfony Console命令和Cron定时任务的解决方案,详细阐述了如何通过这种方式实现低量级、非实时邮件的…

    2025年12月13日
    000
  • PHP中解析和遍历GeoJSON多边形坐标数据

    本教程详细讲解如何在php中解析和遍历geojson格式的多边形坐标数据。首先,利用`json_decode()`函数将json字符串转换为php可操作的数组结构。接着,通过多层数组访问和`foreach`循环,高效地提取出每个经纬度坐标对。文章提供示例代码,帮助开发者理解并应用于实际数据处理场景。…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信