WooCommerce - 根据自定义字段添加费用

时间:2015-03-27 19:59:39

标签: javascript php wordpress woocommerce checkout

我正在尝试根据是否已添加选中的自定义复选框为结帐添加费用。我真的很接近让这个工作,但我在获取帖子值以确定是否应该收取费用时遇到问题。

以下是我的自定义字段的代码:

add_action( 'woocommerce_after_checkout_billing_form', 'my_custom_fields' );
function my_custom_fields( $checkout ) {


  echo '<div id="message_fields"><h3>' . __('Add a Message') . '</h3>';
    woocommerce_form_field( 'add_gift_message', array(
        'type'          => 'checkbox',
        'class'         => array('gift_message form-row-wide'),

        'label'         => __('5x7 Enclosed Personal Message - $4'),
        'placeholder'   => __(''),
        ), $checkout->get_value( 'add_gift_message' ));

    woocommerce_form_field( 'gift_message', array(
        'type'          => 'textarea',
        'class'         => array('gift_message_text form-row-wide'),

        'label'         => false,
        'placeholder'   => __('Your message'),
        ), $checkout->get_value( 'gift_message' )); 
    echo '</div>';
}

这很有效,而且这些字段完美呈现。

在我的主题中的form-checkout.php的底部,我添加了这个javascript来更新购物车总数时检查的字段:

<script type="text/javascript">
jQuery( document ).ready(function( $ ) {

$('#add_gift_message').click(function(){
    if ( $(this).is(':checked') ) { 
        $('#gift_message_field').show();
        var gift_message= true;
    } else { 
        $('#gift_message_field').hide();
        var gift_message = false;
    }
    $.ajax({
        type:       'POST',
        url:        wc_checkout_params.ajax_url,
        data:       $( 'form.checkout' ).serialize(),
        success:    function( response ) {
                if ( response ) {
                        var order_output = $(response);
                        $( '#order_review' ).html( $.trim( order_output ) );
                        $('body').trigger('update_checkout');
                    }
        },
        error: function(code){
        },
        dataType: 'html'
    });
});
});
</script>

这会更新订单总数并运行以下代码(这就是问题所在)

add_action( 'woocommerce_cart_calculate_fees', 'woo_add_cart_fee' );

function woo_add_cart_fee( $data ){
    global $woocommerce;

    if ( isset($_POST['add_gift_message']) )
        $woocommerce->cart->add_fee( 'Personal Gift Message', '4.00', true, 'standard' );

}

我知道这个部分正在被调用,因为如果我拿出 if(isset($ _ POST [&#39; add_gift_message&#39;])),它会增加费用。我遇到的问题是确定是否已经检查过该字段 - 无论我做什么,我都无法在woo_add_cart_fee中获取POST值。

有谁知道如何让它发挥作用?谢谢!!

1 个答案:

答案 0 :(得分:-1)

您无法从$_POST['add_gift_message']获取价值的原因是update_checkout是一个ajax事件,它将表单数据序列化为$_POST['post_data']。因此,为了满足在(ajax)之前和(非ajax)用户结账期间获取价值,您可以使用以下代码来获取该值:

if ( isset( $_POST['post_data'] ) ) {
    parse_str( $_POST['post_data'], $post_data );
} else {
    $post_data = $_POST; // fallback for final checkout (non-ajax)
}

if ( isset( $post_data['add_gift_message'] ) ) {

    $woocommerce->cart->add_fee( 'Personal Gift Message', '4.00', true, 'standard' );
}

供参考,可以看到此post