0

0

为 WooCommerce 订单管理页面添加可编辑的自定义里程字段

碧海醫心

碧海醫心

发布时间:2025-07-14 17:42:02

|

512人浏览过

|

来源于php中文网

原创

为 woocommerce 订单管理页面添加可编辑的自定义里程字段

本教程旨在指导开发者如何在 WooCommerce 订单管理页面添加一个可编辑的自定义字段,用于记录车辆服务的总里程数。我们将详细讲解如何添加输入框、保存用户输入的数据到数据库,以及如何在订单详情页显示该自定义字段的值,从而实现订单里程信息的记录和管理。

在 WooCommerce 网站中,有时需要为订单添加一些自定义信息,例如车辆服务的总里程数。本教程将介绍如何在订单管理页面添加一个可编辑的字段,用于输入和保存这些自定义数据。

添加自定义字段到订单管理页面

首先,我们需要在订单管理页面添加一个输入框,让管理员可以输入总里程数。可以使用 woocommerce_admin_order_data_after_order_details 钩子来实现这一点。

add_action( 'woocommerce_admin_order_data_after_order_details', 'editable_order_custom_field', 12, 1 );
function editable_order_custom_field( $order ){
    $order_id = $order->get_id(); // 获取订单 ID
    $custom_km = get_post_meta( $order_id, 'custom_km', true ); // 获取已保存的里程数,如果存在

    woocommerce_wp_text_input( array(
        'id'            => 'custom_km',
        'label'         => __("Total Km:", "woocommerce"),
        'value'         => $custom_km, // 设置输入框的默认值
        'wrapper_class' => 'form-field-wide',
    ) );
}

这段代码会在订单详情页的订单信息之后添加一个名为 "Total Km:" 的文本输入框。woocommerce_wp_text_input 是 WooCommerce 提供的一个便捷函数,用于生成文本输入框。

注意: 我们添加了获取订单ID的代码 $order_id = $order->get_id(); 和获取已保存里程数的代码 $custom_km = get_post_meta( $order_id, 'custom_km', true );,从而确保在编辑现有订单时,输入框会显示之前保存的值。

保存自定义字段的值

仅仅添加输入框是不够的,还需要将用户输入的值保存到数据库中。可以使用 woocommerce_process_shop_order_meta 钩子来保存数据。

add_action( 'woocommerce_process_shop_order_meta', 'save_custom_filed_data' );

function save_custom_filed_data( $order_id ){
    if ( isset( $_POST['custom_km'] ) ) { // 检查 custom_km 是否存在
        update_post_meta( $order_id, 'custom_km', wc_clean( $_POST['custom_km'] ) );
    }
}

这段代码会在订单保存时,获取 custom_km 字段的值,并使用 update_post_meta 函数将其保存到数据库中。wc_clean 函数用于清理用户输入的数据,防止恶意代码注入。

网奇IOS智能在线订单系统
网奇IOS智能在线订单系统

产品简介: 网奇IOS智能订单系统,是网奇公司研发的一款智能在线订单编辑以及管理系统。本系统适合使用在;在线报名、酒店预定、信息反馈、在线订单和在线投诉等等诸多应用上。本系统所有选项字段完全通过后台控制,在线报名系统可以变为在线预定系统,同时可以变为任何其它的系统,里面的栏目字段,可以任意添加、删除、 修改。本系统为网奇公司全国独家首创,顺应网络需求,安装十分便利,上传即可使用。产品特色:

下载

注意: 添加了 if ( isset( $_POST['custom_km'] ) ) 判断,确保在POST请求中存在 custom_km 字段时才执行保存操作,避免出现未定义索引的错误。

显示自定义字段的值

最后,我们需要在订单详情页显示保存的里程数。可以使用 woocommerce_admin_order_data_after_billing_address 钩子来实现这一点。

add_action('woocommerce_admin_order_data_after_billing_address', 'display_the_custom_distance_km', 10, 1);
function display_the_custom_distance_km($order)
{
    $custom_km = get_post_meta($order->get_id(), 'custom_km', true); // 获取里程数

    if ($custom_km) { // 检查里程数是否存在
        echo '

Custom Km:
' . esc_html($custom_km) . '

'; } }

这段代码会在订单详情页的账单地址之后显示 "Custom Km:" 以及对应的里程数。get_post_meta 函数用于从数据库中获取保存的里程数。 esc_html() 函数用于对输出进行转义,以防止 XSS 攻击。

注意: 添加了 $custom_km 变量来获取里程数,并添加了 if ($custom_km) 判断,确保在里程数存在时才显示,避免显示空的 "Custom Km:" 标签。

总结

通过以上步骤,我们成功地在 WooCommerce 订单管理页面添加了一个可编辑的自定义里程字段,并实现了数据的保存和显示。 这个方法可以扩展到其他类型的自定义字段,以满足不同的业务需求。 关键在于理解 WooCommerce 的钩子系统,并合理使用 woocommerce_wp_text_input、update_post_meta 和 get_post_meta 等函数。 记住始终对用户输入进行清理和转义,以确保网站的安全。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

713

2023.08.22

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

333

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2068

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

346

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

251

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

402

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

371

2023.10.16

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

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

65

2025.12.31

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

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

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