Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
0 / 0 / 1
Регистрация: 29.06.2014
Сообщений: 48

Невозможно добавить новый блок в динамическое меню

21.07.2016, 20:26. Показов 659. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ради эксперимента решил написать динамическое меню. Меню работает. Но добавить новый блок, уже не возможно, потому что перестает работать один из блоков id которого не совпадает с описанным в скрипте. Как его доработать проблемный скрипт что бы при добавлении нового разворачивались оба.
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
   <html>
    <head>
        <title>Домашний бухгалтер 1.0</title>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
        <style>
            .menu ul {
                         margin: 0;
                         list-style: none;
                         padding-left: 5px;
                         display: none;
                     }
                 .menu .title {
                                font-size: 80px;
                                cursor: pointer;
                              }
                 .menu .title::before {
                                             content: url(img/close.png);
                                             font-size: 100%;
                                             color: green;
                                      }
                 .menu.clik .title::before  {
                                                 content: url(img/open.png);
                                            }
                .menu.clik ul {
                                    display: block;
                              }
                     .licat:hover {
                                      background:#51AE3A;
                                  }
            .menu li {
                         font-size: 25px;
                         border-style: outset;
                         border-color: #CCFFCC;
                         border-width: 5px ;
                         border-height: 5px;
                     }
            
         </style>
        <style>
             div {
                      width: 350px;
                      height:80px;
                      border-style: solid;
                      border-width: 8px;
                      border-color: #33CCFF;
                      background-color: #9933FF;
                 }
        </style>
</head>
<body>
<div id="clicked" class="menu">
    <span class="title">Меню</span>
    <ul>
      <li  class="licat" >Учет газа</li>
      <li class="licat">Учет воды</li>
      <li class="licat">Учет електроснабжения</li>
      <li class="licat">Телефония и Интеррнет</li>
    </ul>
</div>
<script>
    alert("Меню закрыто.Для того чтобы его открыть нажмите на "Меню" или на стреке рядом.");
</script>
<script>
    var menuElem = document.getElementById('clicked');//Как я понимаю здесь скрипт находит элемент по id 
      var titleElem = menuElem.querySelector('.title');//видимо строит список дочерних элементов 
      titleElem.onclick = function () {
          menuElem.classList.toggle('clik'); //Как зациклить или преобразовать script добавив каких-то функций, чтоб при  
                                                        //  изменении количества блоков не страдала их функциональность. Сейчас при 
                                                       //добавлении работает только один блок второй не разворачивается. 
 
    };
</script>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js">
</script>
<script type="text/javascript">
    $('span')
    .data('counter', 0)
    .click(function () {
        var counter = $(this).data('counter');
        $(this).data('counter', counter + 1);
        if (counter == 0 || counter % 2 == 0) {
            alert("Меню открыто. Для того чтобы его закрыть нажмите на "Меню" или на стреке рядом.");
        }
        else {
            alert("Меню закрыто.Для того чтобы его открыть нажмите на "Меню" или на стреке рядом.");
        }
    });
</script>
</body>
</html>
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.07.2016, 20:26
Ответы с готовыми решениями:

Как добавить новый пункт меню на страницу
Люди!! Кто нибудь знает как здесь можно добавить вкладку!!!??? Ненадлежащее оформление тем. Перечитайте, пожалуйста, Правила форума ...

Как добавить в пункт меню новый пукт программно
Доброе утро, делаю приложение пытаюсь сделать учусь (. Суть программы в том что каждый год вносят именна сотрудников, вот что я придумал...

Как добавить новый элемент к системному меню формы
http://www.microsoft.ru/msdn/library/kolesov/tips/0002-1.htm#tip237 ^^^^^^^^^^^^^^ Вот тут пример Ну а вот как его обработать в...

2
 Аватар для massEffect
80 / 80 / 53
Регистрация: 22.03.2013
Сообщений: 271
22.07.2016, 21:17
Вы подразумевали сделать подобное:
HTML5
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
91
92
93
94
95
96
97
<html>
<head>
    <title>Домашний бухгалтер 1.0</title>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
    <style>
        .menu{
            display:inline-block;
            vertical-align: top;
        }
        .menu ul {
            margin: 0;
            list-style: none;
            padding-left: 5px;
            display: none;
        }
        .menu .title {
            font-size: 80px;
            cursor: pointer;
        }
        .menu .title::before {
            content: url(img/close.png);
            font-size: 100%;
            color: green;
        }
        .menu.clik .title::before  {
            content: url(img/open.png);
        }
        .menu.clik ul {
            display: block;
        }
        .licat:hover {
            background:#51AE3A;
        }
        .menu li {
            font-size: 25px;
            border-style: outset;
            border-color: #CCFFCC;
            border-width: 5px ;
            border-height: 5px;
        }
 
    </style>
    <style>
        div {
            width: 350px;
            height:80px;
            border-style: solid;
            border-width: 8px;
            border-color: #33CCFF;
            background-color: #9933FF;
        }
    </style>
</head>
<body>
<div  class="menu">
    <span class="title">Меню</span>
    <ul>
        <li  class="licat" >Учет газа</li>
        <li class="licat">Учет воды</li>
        <li class="licat">Учет електроснабжения</li>
        <li class="licat">Телефония и Интеррнет</li>
        <li class="licat">Учет електроснабжения</li>
        <li class="licat">Телефония и Интеррнет</li>
    </ul>
</div>
<div  class="menu">
    <span class="title">Меню</span>
    <ul>
        <li  class="licat" >Учет газа</li>
        <li class="licat">Учет воды</li>
    </ul>
</div>
<div  class="menu">
    <span class="title">Меню</span>
    <ul>
        <li  class="licat" >Учет газа</li>
        <li class="licat">Учет воды</li>
        <li class="licat">Учет електроснабжения</li>
    </ul>
</div>
 
 
<script>
    var arrMenuElem = document.getElementsByClassName('menu');
    for(var i = 0; i < arrMenuElem.length; i++){
        var titleElem = arrMenuElem[i].querySelector('.title');
        (function(i){
            titleElem.onclick = function () {
            arrMenuElem[i].classList.toggle('clik');
            };
        }(i));
    };
 
</script>
 
</body>
</html></html>
или я неправильно понял?
1
0 / 0 / 1
Регистрация: 29.06.2014
Сообщений: 48
23.07.2016, 11:48  [ТС]
Спасибо, это именно то что я подразумевал сделать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.07.2016, 11:48
Помогаю со студенческими работами здесь

Добавить в Popup-меню Windows Explorer новый пункт
Собственно название темы и есть вопрос,хочу сделать дабы при клике правой кнопкой мыши на файле bmp в popupmenu появился пункт...

Невозможно добавить строки в элемент управления DataGridView, в котором нет столбцов. Сначала необходимо добавить столбцы
Дан массив студентов ВУЗа: ФИО, возраст, регион, факультет. Вывести на экран результирующую таблицу: регион, количество студентов из этого...

Как добавить выплывающее меню к уже готовому горизонтальному меню (не меняя дизайн горизонтального меню)?
&lt;!DOCTYPE html PUBLIC &quot;-//W3C//DTD XHTML 1.0 Strict//EN&quot; &quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd&quot;&gt; &lt;html...

Добавить меню к итему меню, который уже находится в главном меню
Как можно программно добавить подменю к итему меню, который находится в главном меню? Чтобы выглядело это как-то наподобие того, что на...

Невозможно добавить реквизиты!
Здравствуйте! У меня появился такой глюк в 8.2 версии: Поставил 10.77. Сначала всё нормально работало. После 2 месяцев работы после...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru