感谢StackOverflow的所有开发人员 .
我想在Woocommerce的Linked Product部分添加更多字段 . 这些字段应与Upsell / Crosssell类似 .
我的代码到目前为止: -
add_action( 'woocommerce_product_options_linked_product_data', 'woocom_general_product_data_custom_field' );
woocommerce_wp_text_input(
array(
'id' => '_upsizing_products',
'label' => __( 'Upsizing Products', 'woocommerce' ),
'placeholder' => 'Upsizing Products',
'desc_tip' => 'true',
'description' => __( 'Select Products Here', 'woocommerce' )
)
);
在上面的代码中,我需要组合框,例如,当您在输入框中键入3个字符时,它将显示可以选择的匹配产品列表 . 与Upsell / Cross Sell类似 .
请任何人帮我实现此自定义字段 . 提前致谢 .
编辑:有人吗?
1 回答
上面的代码中缺少一些内容 .
您在第一行使用的钩子不存在 . 右钩子被称为
woocommerce_product_options_related
您设计自定义字段的代码不在任何函数内 .
您正在创建标准文本字段 . 如果你想要"Select Product" -downdown,你应该使用另一种方法 . 这应该在你在钩子中使用的函数内部 .
您缺少一个钩子和一个实际保存自定义字段数据的函数
1.找到合适的挂钩/动作
要找到要使用的正确挂钩,只需在WoocCommerce插件中搜索"woocommerce_product_options_",就会出现大约6个PHP文件 . 其中一个文件名为"html-product-data-linked-products.php" . 此文件包含该特定WooCommerce部分中的所有现有选项 . 它还包含用于显示这些选项的钩子 .
打开文件并检查出来 . 钩子位于页面的底部
2.创建下拉列表
要创建包含产品搜索的选择下拉列表,您需要与上述代码完全不同的代码 .
闲置一段时间,您可以在上面提到的文件中复制粘贴一个现有选项,然后根据您的需要进行修改 .
所有这些都应该放在一个名为:
woocom_linked_products_data_custom_field()
的函数中 .2.1. Modify the ID/name
您需要在代码中修改的第一件事当然是该字段的唯一ID /名称 . 它位于
label
-tag(for
)和select
-tag(id
和name
)中 .在您的示例中,ID /名称应为
upsizing_products
,标签文本为Upsizing Products
:2.2. Show already chosen products
接下来,就是在WooCommerce部分中展示和选择已经选择的产品以及它自己的下拉列表 .
要执行此操作,请将
$product_ids
变量和整行替换为:相反,使用数据库中的自定义字段而不是现有选项之一(例如cross_sell_ids)检索产品ID .
2.3. Display the field in the WooCommerce section
最后,该函数应该正确挂钩,因此它可以显示在 Linked Products 部分:
3.保存并存储数据
现在,您的自定义字段显示在右侧部分中 . 接下来是将数据保存并存储在数据库中 .
在新函数中,使用
$_POST
从字段中检索数据,并使用update_post_meta
将数据存储在包含post-ID,唯一字段id /名称(元键)和自身数据的数据库中(meta-值) .这是完整的代码 . 把它放在你的主题
functions.php
或插件文件中:要显示存储的数据,请使用
_upsizing_products_ids
: