在 WooCommerce 单个产品和购物车页面中输出自定义字段值

Output a custom field value in WooCommerce single product and cart pages

我需要帮助在产品前端添加自定义数据,就像这样:

这张图片是一个示例,如果 PD # 我只是添加并且我希望它添加在产品的前端:

刚刚在 WooCommerce 产品页面常规设置选项卡中添加自定义字段,借助于: 感谢@Ankur Bhadania。

谢谢

为了在信号产品页面中显示自定义产品元数据,使用了 2 个挂钩。根据您的要求使用其中任何一种。

1) display before WooCommerce product meta. used woocommerce_product_meta_start

add_action( 'woocommerce_product_meta_start', 'woo_add_custom_general_fields_extra_info' );
function woo_add_custom_general_fields_extra_info()
{
     global $woocommerce, $post;
     echo "PD # ".get_post_meta( $post->ID, '_text_field', true );

}

2) display after WooCommerce product meta. used woocommerce_product_meta_end

add_action( 'woocommerce_product_meta_end', 'woo_add_custom_general_fields_extra_info' );
function woo_add_custom_general_fields_extra_info()
{
     global $woocommerce, $post;
     echo "PD # ".get_post_meta( $post->ID, '_text_field', true );

}

对于简单产品,您的产品 '_pd_number' 在添加到购物车之前在简单产品页面中自定义字段,使用 woocommerce_before_add_to_cart_button 操作挂钩,如下所示:

add_action( 'woocommerce_before_add_to_cart_button', 'add_cf_before_addtocart_in_single_products', 1, 0 );
function add_cf_before_addtocart_in_single_products()
{
     global $product;

     $pd_number = get_post_meta( $product->get_id(), '_pd_number', true );
     if( !empty( $pd_number ) )
        echo '<div class="pd-number">PD # '. $pd_number .'</div><br>';

}

代码进入您的活动子主题(或主题)的 function.php 文件或任何插件文件。

此代码已在 WooCommerce 版本 3+ 上测试并有效。


您还可以在名称下方的购物车项目中输出您的产品自定义字段,使用 woocommerce_cart_item_name 过滤器挂钩,如下所示:

// Displaying the product custom field in the Cart items
add_filter( 'woocommerce_cart_item_name', 'add_cf_after_cart_item_name', 10, 3 );
function add_cf_after_cart_item_name( $name_html, $cart_item, $cart_item_key )
{
    $product_id = $cart_item['product_id'];
    if( $cart_item['variation_id'] > 0 )
        $product_id = $cart_item['variation_id'];

     $pd_number = get_post_meta( $product_id, '_pd_number', true );;
     if( !empty( $pd_number ) )
        $name_html .= '<br><span class="pd-number">PD # '.$pd_number .'</span>';

     return $name_html;
}

代码进入您的活动子主题(或主题)的 function.php 文件或任何插件文件。

此代码已在 WooCommerce 版本 3+ 上测试并有效。


这里是我使用的代码,他在评论中提供 link 仅用于测试:

// Display Product settings Fields
add_action( 'woocommerce_product_options_general_product_data', 'woo_add_custom_general_fields' );
function woo_add_custom_general_fields() {
    woocommerce_wp_text_input( array(
        'id'          => '_pd_number',
        'label'       => __( 'PD Number', 'woocommerce' ),
        'placeholder' => 'PD# XXXXXX',
        'desc_tip'    => 'true',
        'description' => __( 'Enter the PD Number of Product', 'woocommerce' )
    ));
}

// Save Product settings Fields
add_action( 'woocommerce_process_product_meta', 'woo_add_custom_general_fields_save' );
function woo_add_custom_general_fields_save( $post_id ){
    $pd_number = $_POST['_pd_number'];
    if( !empty( $pd_number ) )
        update_post_meta( $post_id, '_pd_number', esc_attr( $pd_number ) );
}

相关回答: