Выбор страны / штата цепочки jQuery с помощью OptGroup

#jquery

#jquery

Вопрос:

У меня есть следующие 2 списка выбора.. Я бы хотел скрыть состояние / состояние, пока выбранная страна не будет иметь соответствующую метку optgroup. So..

—Пользователь выбирает Alegeria.. Выбор состояния не отображается..

—Пользователь выбирает Соединенные Штаты или Канаду; Отображается выбранное состояние, отображающее только те значения, где метка optgroup совпадает с именем родителей.

Имеет смысл? Не удается найти способ сделать это на основе OptGroup или необходимости вручную назначать «класс» каждому дочернему объекту

 <select id="C_Country" name="C_Country" aria-required="true" class="required">
    <option value=" " selected="">-- Please Select --</option>
    <option value="AF">Afghanistan</option>
    <option value="AX">Aland Islands</option>
    <option value="USA">United States</option>
    <option value="DZ">Algeria</option>
    <option value="CA">Canada</option>
    <option value="AD">Andorra</option>
</select>


<p><label for="C_State_Prov">State or Province <span title="required">*</span></label></p>
<select id="C_State_Prov" name="C_State_Prov" aria-required="true" class="required">
    <option value="" selected="">-- Please Select --</option>
    <optgroup label="United States">
    <option value="AK">Alaska</option>
    <option value="AL">Alabama</option>
    <option value="AR">Arkansas</option>
    <option value="AZ">Arizona</option>
    <option value="CA">California</option>
    </optgroup>
    <optgroup label="Canada">
    <option value="AB">Alberta</option>
    <option value="BC">British Columbia</option>
    <option value="MB">Manitoba</option>
    </optgroup>
</select>
  

Ответ №1:

Я думаю, это то, что вы хотите.

 $(function(){
   var state_province = $('#C_State_Prov option, #C_State_Prov optgroup'); 
   state_province.hide();  // hide all state and provinces on page load


   $('#C_Country').change(function(){
       state_province.hide(); // on change of drop down hide all state provinces

       // find the optgroup with the label = the html of the selected dropdown 
       // select the opt group and all of it's children and show them 
       $("#C_State_Prov optgroup[label='" $(this).find(':selected').html()   "']")
       .children()
       .andSelf()
       .show();  
   }); 
}); 
  

Это можно еще немного почистить, но вы поняли идею.