Теперь Кью работает в режиме чтения

Мы сохранили весь контент, но добавить что-то новое уже нельзя

Как изменять (фильтровать) второй/третий список в зависимости от выбора в первом/втором?

Нашел вот такой код, но нужно чтобы можно было выбирать не последовательно, а напрямую.

Есть варианты с таблицей, но не подходят - разное количество строк 10 в первом списке (столбце), 2 - 100, в 3 - 1000.

А как сделать чтобы все списки изначально были видны (с полосой прокрутки) и можно было обращаться напрямую - сразу нажимаешь, например московская область и отфильтровывается третий список или нажимаешь Россия и отфильтровываются все области и города из России, которые доступны для прямого обращения. Соответственно во всех списках есть опция "ВСЕ" при выборе которой в зависимых списках отображаются все элементы. Из примера выше при выборе "ВСЕ" из областей отображаются все города но для выбранной страны (если была выбрана!) А при выборе "ВСЕ" из стран отображаются и все области и все города.

Выбланное значение из 3го списка будет отправляться в форму

Спасибо

Страна:

<select id="country_id" class="StyleSelectBox">

<option value="0">- выберите страну -</option>

<option value="1">Россия</option>

<option value="2">Украина</option>

<option value="3">Белорусь</option>

</select>

Регион:

<select id="region_id" disabled>

<option value="0">- Выберите регион -</option>

</select>

Город:

<select id="city_id" disabled>

<option value="0">- Выберите город -</option>

</select>

<script>

var all_regions=[];

var all_cites=[[],[],[]];

all_regions[0]=["московская обл","ростовская обл","саратовская обл"];

all_regions[1]=["киевская обл","львовская обл","харьковская обл"];

all_regions[2]=["минская обл","брестская обл","гроднинская обл"];

all_cites[0][0]=["Москва","Химки","Калуга"];

all_cites[0][1]=["Такой-то город","Такой-то город","Калуга"];

all_cites[0][2]=["Такой-то город","Такой-то город","Такой-то город"];

all_cites[1][0]=["Киев","Жмеринка","Бердычев"];

all_cites[1][1]=["Львов","Сокаль","Стрый"];

all_cites[1][2]=["Харьков","Полтава","Пирятин"];

all_cites[2][0]=["Минск","Такой-то город","Такой-то город"];

all_cites[2][1]=["Брест","Такой-то город","Такой-то город"];

all_cites[2][2]=["Гродно","Такой-то город","Вильно"];

country_id.onchange = function() {

region_id.disabled = false;

region_id.innerHTML = "<option value='0'>- Выберите регион -</option>";

myregion = this.value - 1;

if (myregion != -1) {

for (var i = 0; i < all_regions[myregion].length; i++) {

region_id.innerHTML += '<option value="' + (i+1) + '">' + all_regions[myregion][i] + '</option>';

}

} else {

region_id.disabled = true;

city_id.disabled = true;

}

}

region_id.onchange = function() {

city_id.disabled = false;

city_id.innerHTML = "<option value='0'>- Выберите город -</option>";

var mycite = this.value - 1;

if (mycite != -1) {

for (var i = 0; i < all_cites[myregion][mycite].length; i++){

city_id.innerHTML += '<option value="' + (i + 1) + '">' + all_cites[myregion][mycite][i] + '</option>';

}

} else {

city_id.disabled = true;

}

}

</script>

https://jsfiddle.net/kLxp0m24/

ПрограммированиеJavascript
Алексей ---
  · 236
На Кью задали 1 похожий вопрос