【问题标题】:Conditionally unset checkout field in woocommerce在woocommerce中有条件地取消设置结帐字段
【发布时间】:2016-09-03 02:39:54
【问题描述】:

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

表单如下所示:

代码如下:

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' );

【问题讨论】:

    标签: php jquery wordpress woocommerce checkout


    【解决方案1】:
     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;
            }
    

    【讨论】:

      猜你喜欢
      • 2018-02-04
      • 2018-05-23
      • 2018-12-20
      • 2018-01-03
      • 2021-07-01
      • 2018-01-18
      • 2018-12-26
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多