Select options: jQuery, Case and show/hide form fields

前端 未结 5 947
深忆病人
深忆病人 2021-01-06 22:08

What is the most efficient way of showing/hiding form fields based on the value of a select control? I have one select control and three input fields, which show/hide based

相关标签:
5条回答
  • 2021-01-06 22:29

    Few things:

    1) I would add a class (I used .additional-field below) to each of the additional fields. This will allow you to hide them all in one swoop instead of requiring you to $.hide() each one explicitly. It's not so bad with just three, but if you ended up with much more, it'd get hairy quick.

    2) I put the code in a function and both call that function on page load and use it as the parameter to .change(). This saves repeating the same code, and covers the case of an initial value from either editing an existing one or an error in the form that needs to be corrected. Otherwise, the additional field wouldn't show until you chose something else and then chose the item again.

    $(document).ready(function(){
    
        function toggleBusinessTypeAdditionalFields() {
            $('.additional-field').hide();
    
            var selected = $('#business-type').val();
            switch (selected) {
                case 1:
                    $('#soletrader').show();
                    break;
                case 3:
                    $('#publicsector').show();
                    break;
                case 5:
                    $('#charity').show();
                    break;
            }
        }
        toggleBusinessTypeAdditionalFields();
        $('#business-type').change(toggleBusinessTypeAdditionalFields);
    
    });
    
    0 讨论(0)
  • 2021-01-06 22:33
    <script type="text/javascript">
                   $('#type_of_bussiness').change(function(){
                var selection = $('#type_of_bussiness').val();
           
                if(selection==1)
    
                   {
                      $('#typeofmargin').css('display','block');
                   }
                   if(selection==2){
                      $('#coloxxcomm').css('display','block');
    
                   }            
                              
                 
             });
          </script>
    
    0 讨论(0)
  • 2021-01-06 22:49

    Put these functions in your $.ready(function(){});

    $('#soletrader').hide();
    $('#publicsector').hide();
    $('#charity').hide();
    
    $('#business-type').change(function(){
       var value = $(this).val();
       if(value == '1'){
         $('#soletrader').show();
         $('#publicsector').hide();
         $('#charity').hide();
       } else if(value == '3'){
         $('#soletrader').hide();
         $('#publicsector').show();
         $('#charity').hide();
       } else if(value == '5'){
         $('#soletrader').hide();
         $('#publicsector').hide();
         $('#charity').show();
       } else {
         $('#soletrader').hide();
         $('#publicsector').hide();
         $('#charity').hide();
       }
    });
    
    0 讨论(0)
  • 2021-01-06 22:51

    First, you should add "class='field'" to each field div.

    Then, with this code, you will show/hide the appropriate field upon selction in the dropdown:

    $('#business-type').change(function(){
        var selection = $('#business-type').val();
        $('.field').hide();
        switch(selection){
            case 0:
                $('#soletrader').show();
                break;
            case 1:
                $('#publicsector').show();
                break;
            case 2:
                $('#charity').show();
                break;
        }
    });
    
    0 讨论(0)
  • 2021-01-06 22:55

    I don't think an if/switch statement is necessary. Help your JavaScript out a bit with a little more HTML markup. If you put an attribute named "data-val" on each of the divs, and assign it the value of the option you want it to appear along with, then the JS becomes very simple.

    So your HTML would look something like this for the divs:

    <div id="soletrader" data-val="1">
        <label for="tax">VAT Number</label>
        <input type="text" name="tax" id="tax" /> 
    </div>
    

    And then your JS would be:

     $('select').change(function(){
         var val = $(this).val();
         $('div').hide().filter('[data-val=' + val + ']').show();
     });
    
    0 讨论(0)
提交回复
热议问题