在woocommerce中有条不紊地设置结帐领域 [英] Conditionally unset checkout field in woocommerce

查看:78
本文介绍了在woocommerce中有条不紊地设置结帐领域的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

如何从服务器端有条件地取消设置其他两个字段并从中删除所需的验证?

How can I conditionally unset the other two fields from server side and remove the required validation from it?

以下是表单的外观:

Here is how the form looks like:

以下是代码:

function bs_filter_checkout_fields($fields){
    $fields['billing'] = array(

        'add_type' => array(
            'type' => 'radio',
            'label' => __( 'Address Type' ),
            'options' => array( 'house' => __( 'House' ), 'building' => __( 'Building' ), 'office' => __( 'Office' ) ),
            'required' => true
                ),
        'add_house_name' => array(
            'type' => 'text',
            'required'      => true,
            'placeholder' => __( 'House Name/Number' ),
            'label' => __( 'House Name/Number' )
        ),
        'add_building_name' => array(
            'type' => 'text',
            'required'  => true,
            'placeholder' => __( 'Building Name/Number' ),
            'label' => __( 'Building Name/Number' )
        ),
        'add_office_name' => array(
            'type' => 'text',
            'required'  => true,
            'placeholder' => __( 'Office Name/Number' ),
            'label' => __( 'Office Name/Number' )
        ),
    );
return $fields;
}
add_filter( 'woocommerce_checkout_fields', 'bs_filter_checkout_fields' );
function bs_conditional_scripts() {
    wc_enqueue_js( "
        $( '#add_type_house' ).change( function () {

            if ( $( this ).is( ':checked' ) ) {
                $('#add_building_name_field').hide();
                $('#add_office_name_field').hide();
                $( '#add_house_name_field' ).show();
            }

        } ).change();

    $( '#add_type_building' ).change( function () {

        if ( $( this ).is( ':checked' ) ) {
            $( '#add_house_name_field' ).hide();
            $('#add_office_name_field').hide();
            $('#add_building_name_field').show();
        }

    } ).change();


    $( '#add_type_office' ).change( function () {

        if ( $( this ).is( ':checked' ) ) {
            $( '#add_house_name_field' ).hide();
            $('#add_building_name_field').hide();
            $('#add_office_name_field').show();
        }

    } ).change();
    " );
}

add_action( 'wp_enqueue_scripts', 'bs_conditional_scripts' );


推荐答案

 function bs_filter_checkout_fields($fields){ 
                     $fields['billing'] = array(
                          'add_type' => array(
                                'type' => 'radio',
                                'label' => __( 'Address Type' ),
                                'options' => array( 'house' => __( 'House' ), 'building' => __( 'Building' ), 'office' => __( 'Office' ) ),
                                'required' => true
                                ),
                            'add_house_name' => array(
                                'type' => 'text',
                                'required'      => true,
                                'placeholder' => __( 'House Name/Number' ),
                                'label' => __( 'House Name/Number' )
                                ),
                            'add_building_name' => array(
                                'type' => 'text',
                                'required'  => true,
                                'placeholder' => __( 'Building Name/Number' ),
                                'label' => __( 'Building Name/Number' )
                                ),
                            'add_office_name' => array(
                                'type' => 'text',
                                'required'  => true,
                                'placeholder' => __( 'Office Name/Number' ),
                                'label' => __( 'Office Name/Number' )
                                ),
                            );
        if( true ){ // pass conditional statement here
          unset($fields['billing']['add_house_name']);  //  remove field
          $fields['billing']['add_building_name']['required']   = false; // remove required validation
        }                   
        return $fields;
        }

这篇关于在woocommerce中有条不紊地设置结帐领域的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆