Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/22: Рейтинг темы: голосов - 22, средняя оценка - 5.00
SysOp
 Аватар для IamSCORPION
42 / 41 / 5
Регистрация: 13.04.2009
Сообщений: 274

Связанные списки

26.04.2010, 15:23. Показов 4307. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите как переделать данный код так чтобы связанные были три списка и при выборе пункта в первом списке данные в двух других были одинаковые

PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=windows-1251">
<title>Списки</title>
<script type="text/javascript">
function syncList()
{}
 
syncList.prototype.sync = function()
{
    for (var i=0; i < arguments.length - 1; i++)
    {   
        document.getElementById(arguments[i]).onchange = (function (o, id1, id2) { return function() { o._sync(id1, id2); }; }) (this, arguments[i], arguments[i+1]);
    }
    document.getElementById(arguments[0]).onchange();
}
 
syncList.prototype._sync = function (firstSelectId, secondSelectId)
{
    var firstSelect = document.getElementById(firstSelectId);
    var secondSelect = document.getElementById(secondSelectId);
 
    secondSelect.length = 0;
    
    if (firstSelect.length > 0)
    {
        var optionData = this.dataList[firstSelect.options[firstSelect.selectedIndex == -1 ? 0 : firstSelect.selectedIndex].value];
        for (var key in optionData || null) 
        {
            secondSelect.options[secondSelect.length] = new Option(optionData[key], key);
        }
        
        if (firstSelect.selectedIndex == -1) 
        {
            setTimeout( function(){ firstSelect.options[0].selected = true;}, 1 );
        }
        
        if (secondSelect.length>0) 
        {   
            setTimeout( function(){ secondSelect.options[0].selected = true;}, 1 );
        }
    }
    secondSelect.onchange && secondSelect.onchange();
};
</script>
</head>
    Список 1<br>
        <select style='width:250px;' class='search_form_select' size='1' id='List1'>";
            <option value='0'>- Выбрать лигу -</option>";
            <option value='1'>Лига 1</option>";
            <option value='2'>Лига 2</option>";
        </select>
        <br><br>
        
        Список 2<br>
    <select name='m_home' style='width:130px;' size='1' id='List2'></select>
        <br><br><br>
    Список 3<br>
    <select name='m_visitor' style='width:130px;' size='1' id='List3'></select>
                
                  
 
        <script type="text/javascript">
            var comand = new syncList;
            comand.dataList = 
            {
                '0':
                {
                    '0':'- Выберите лигу -'
                },
 
                '1':
                {
                    'Л1.1':'Лига 1.1',
                    'Л1.2':'Лига 1.2',
                    'Л1.3':'Лига 1.3'
                },
 
                '2':
                {
                    'Л2.1':'Лига 2.1',
                    'Л2.2':'Лига 2.2',
                    'Л2.3':'Лига 2.3'
                }
            };
            comand.sync("List1", "List2", "List3");
        </script>
</body>
</html>
Спасибо)

Гуру, подскажите что делать!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.04.2010, 15:23
Ответы с готовыми решениями:

Связанные списки
Здравствуйте. Вопрос такой: есть два select-a. Необходимо, чтобы при изменении одного менялся список option другого. Код, который за это...

Динамически связанные списки
Господа! Что бы получить точный ответ на вопрос, необходимо точно сформулировать вопрос! В моем случае это создание динамически...

Динамическая замена текста и связанные списки
Всем доброго времени суток! Помогите пожалуйста разобраться с такой вот задачей: есть два селекта, при выборе которых происходит...

1
0 / 0 / 0
Регистрация: 10.12.2016
Сообщений: 2
13.12.2016, 21:58
Не понятна логика, что должно происходить при выборе одного и другого списка.
Если речь действительно о связанных списках, то при выборе в первом, должен появляться и подгружать значения второй список, аналогично - третий. При этом список значений второго должен зависеть от выбора в первом и т.д.
Смотря на datalist - не понятно идея вашего скрипта.

Есть пример универсального скрипта для связанных списков -
http://shra.ru/2016/12/formiro... zhennosti/

Смысл в том, что формат данных в виде дерева представлен, а select-ы формируются динамически.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.12.2016, 21:58
Помогаю со студенческими работами здесь

Как сделать связанные выпадающие списки mysql + ajax ?
Как сделать связанные выпадающие списки mysql + ajax ?

Связанные селекты
Добрый день. Есть 2 селекта. &lt;select id=&quot;select1&quot; name=&quot;select_1&quot;&gt; &lt;option value=&quot;&quot;&gt;Осуществите выбор&lt;/option&gt; &lt;option...

Зависимые списки, снова списки и проблема
&lt;div class=&quot;t-product__option js-product-option newselect&quot;&gt; &lt;div class=&quot;t-product__option-title t-descr t-descr_xxs...

Связанные select на javascript
Доброго времени суток! Я столкнулся с проблемой что мне нужно сделать зависимые списки и исходя из данных 2-ого select'а написать условие...

Связанные списки
Добрый день! Борюсь со связанными списками. Пытаюсь реализовать, как в этом примере...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru