enter image description here

enter image description here

后台添加自定义字段的代码如下:

// 1. Add custom field input @ Product Data > Variations > Single Variation
function bbloomer_add_custom_field_to_variations( $loop, $variation_data, $variation ) {
woocommerce_wp_text_input( array( 
'id' => 'custom_field[' . $loop . ']', 
'class' => 'short', 
'label' => __( 'Custom Field', 'woocommerce' ),
'value' => get_post_meta( $variation->ID, 'custom_field', true )
) 
);      
}
add_action( 'woocommerce_variation_options_pricing', 'bbloomer_add_custom_field_to_variations', 10, 3 ); 
// 2. Save custom field on product variation save
function bbloomer_save_custom_field_variations( $variation_id, $i ) {
    $custom_field = $_POST['custom_field'][$i];
    if ( ! empty( $custom_field ) ) {
        update_post_meta( $variation_id, 'custom_field', esc_attr( $custom_field ) );
    } else delete_post_meta( $variation_id, 'custom_field' );
}
add_action( 'woocommerce_save_product_variation', 'bbloomer_save_custom_field_variations', 10, 2 );
// 3. Store custom field value into variation data
function bbloomer_add_custom_field_variation_data( $variations ) {
    $variations['custom_field'] = '<div class="woocommerce_custom_field">Custom Field: <span>' . get_post_meta( $variations[ 'variation_id' ], 'custom_field', true ) . '</span></div>';
    return $variations;
}
add_filter( 'woocommerce_available_variation', 'bbloomer_add_custom_field_variation_data' );

那么,如何在产品首页的产品标题下同时显示这个新添加的自定义字段和现有的收件箱字段,并且:当 Select 不同的变体时,相应的自定义字段和收件箱字段也会动态显示.

我try 过,但标题下方没有显示

推荐答案

BBloomer的代码有点过时了.

要在产品标题下方显示选定的变体自定义字段,请使用以下内容:

// Add custom field(s) to product variations from specific variable products
add_action( 'woocommerce_variation_options_pricing', 'add_variation_setting_fields', 10, 3 ); 
function add_variation_setting_fields( $loop, $variation_data, $variation ) {
    $field_key = 'custom_field';

    woocommerce_wp_text_input( array( 
        'id'            => $field_key.'['.$loop.']', 
        'label'         => __( 'Custom Field', 'woocommerce' ),
        'class'         => 'short', 
        'wrapper_class' => 'form-row',
        'value'         => get_post_meta( $variation->ID, $field_key, true )
    ) );      
}

// Save the custom field from product variations
add_action('woocommerce_admin_process_variation_object', 'save_variation_setting_fields', 10, 2 );
function save_variation_setting_fields($variation, $i) {
    $field_key = 'custom_field';

    if ( isset($_POST[$field_key][$i]) ) {
        $variation->update_meta_data($field_key, sanitize_text_field($_POST[$field_key][$i]));
    }
}

// Add the custom field value to the product form data
add_filter( 'woocommerce_available_variation', 'available_variation_custom_field_value', 10, 3 );
function available_variation_custom_field_value( $variation_data, $product, $variation ) {
    $variation_data['custom_field'] = $variation->get_meta('custom_field');
    return $variation_data;
}
    
// Display selected variation custom field below product title
add_action('woocommerce_single_product_summary', 'display_custom_field_below_product_title', 7 );
function display_custom_field_below_product_title() {
    global $product;

    if ( $product->is_type('variable') ) :

    wc_enqueue_js("$('form.variations_form').on('show_variation', function(event, data){
        if ( data.custom_field ) {
            $('.custom-field').html(data.custom_field).show();
        }
    }).on('hide_variation', function(){
        $('div.custom-field').hide().html('');
    });");

    echo '<div class="custom-field" style="display:none;"></div>';

    endif;
}

代码保存在您的子主题的functions.php文件中(或插件中).经过测试并工作.

Php相关问答推荐

Laravel:让所有用户在一年中的特定月份休息几天

如何限制WordPress自定义分类术语页面中的术语数量

根据未用于变体的产品属性隐藏WooCommerce发货方式

EBay Inventory API createOrReplaceInventoryItem出错

闭包绑定$This和垃圾收集器

如何在WooCommerce产品子类别中显示特定内容

将WooCommerce WC_Order对象与wp_Schedule_Event一起使用

Codeigniter 4中的未定义变量$HOME

PHP:使用FORT从数据库获取USERS表到AUTH表

PHP SimpleXML:按属性值访问 node

为WooCommerce中存储一些数据的购物车项目添加复选框

Regex|PHP捕获json字符串中的每个非法双引号

Woocommerce 临时购物车税未根据第一个请求正确计算

如何在 PHP 中以 hh:mm:ss 格式获取两个 strtotime datetime/s 之间的时间差

MongoDB Laravel Jenssegers 包:插入数据库时​​未定义的类常量PRIMARY

如何搜索和替换 XML 文件中的一段文本?

如何通过帖子自定义元数据进行查询

Laravel使用另一张表进行关联查询

Woocommerce API 的 PHP Curl 附加参数

如何使 Wordpress Woocommerce 自定义输入字段成为必填字段