Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
2 / 2 / 0
Регистрация: 17.12.2014
Сообщений: 156

Раскрывающиеся списки slideToggle

03.05.2020, 16:05. Показов 980. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Хочу сделать чтобы при нажатии на элемент списка у меня открывался (или закрывался если уже открыт) вложенный в него список. Всего три уровня. Для тестирования использую первые элементы, те у которых ссылки никуда не ведут.
В стилях указал скрыть вложенные списки, но при нажатии на ссылку которая содержит элемент с вложенным в него списком раскрываются сразу же все. Т.е. в стилях вроде все скрыто, нажимаю раскрыть список 1 го уровня, а у меня раскрываются вообще все вложенные туда списки.
Как это можно пофиксить ?

Вот как выглядит список
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
        <ul class="category" id="category_id">
        <li><a>Стройматериалы</a>
            <ul>
            <li><a>Гипсокартонные системы</a>
                <ul>
                <li><a href="">Гипсокартонный лист (ГКЛ)</a></li>
                <li><a href="">Гипсоволокнистый лист (ГВЛ)</a></li>
                <li><a href="">Гипсофибровый лист (ГФЛ)</a></li>
                <li><a href="">Стекломагниевый лист (СМЛ)</a></li>
                <li><a href="">Аквапанели</a></li>
                <li><a href="">Профиль для гипсокартона</a></li>
                <li><a href="">Элементы крепления</a></li> 
                </ul></li>
            <li><a href="">Сухие смеси</a></li>
            <li><a href="">Фасадные системы</a></li>
            <li><a href="">Теплоизоляция</a></li>
            <li><a href="">Гидроизоляция</a></li>
            <li><a href="">Звукоизоляция</a></li>
            <li><a href="">Изоляционные пленки</a></li>
            <li><a href="">Кровля</a></li>
            <li><a href="">Общестроительные материалы</a></li>
            <li><a href="">Пиломатериалы</a></li>  
            <li><a href="">Древесно-плитные материалы</a></li>  
            <li><a href="">Пены, герметики, клеи</a></li>  
            <li><a href="">Крепеж</a></li>    
            <li><a href="">Хозяйственный инвентарь</a></li>       
            </ul></li>
        <li><a href="">Отделочные материалы</a></li>
        <li><a href="">Сантехника, отопление и водоснабжение</a></li>
        <li><a href="">Электрика и освещение</a></li>
        <li><a href="">Геоматериалы</a></li>
        <li><a href="">Инструмент и оборудование</a></li>
        <li><a href="">Дача и сад</a></li>  
        </ul>   
    </div>
Написал следующий jq
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
$(document).ready(function() {
$('#category_id > li > a').click(function() {
    if ($(this).parent().find('ul').length) {       
      $(this).parent().find('ul').slideToggle(200); 
 
      return false;
    }
 
  });
 
 
 
 $('#category_id > li > ul > li a').click(function() {
       if ($(this).parent().find('ul').length) {        
      $(this).parent().find('ul').slideToggle(200); 
 
      return false;
 
  };
 
 
});
 
});
Стили

CSS
1
2
3
4
5
6
7
.category ul li ul {
    display: none;
}
 
.category ul {
    display: none;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.05.2020, 16:05
Ответы с готовыми решениями:

Раскрывающиеся списки(в определенном диве)
Скрипт хороший, работающий)) ,но он применяется ко всем тегам &lt;b&gt; и &lt;p&gt; ,которые есть в коде,подскажите как сделать ,чтобы он работал...

SlideToggle() отключить событие для блока внутри блока с .slideToggle()
У меня есть такой скрипт: $(&quot;.cl_item&quot;).click(function() { $(this).children(&quot;.cli_popup&quot;).slideToggle(); }); В...

Html тег <select> раскрывающиеся списки
Доброго времени суток, Суть в следующем, взял код из примера, хочу реализовать следующее: при выборе из списка &quot;Кратко&quot; или...

5
 Аватар для Soldado
901 / 833 / 198
Регистрация: 28.06.2012
Сообщений: 1,607
Записей в блоге: 4
03.05.2020, 17:58
Нужно открыть первый - открывайте первый
строка 4
JavaScript
1
$(this).parent().find('ul:first').slideToggle(200);
0
2 / 2 / 0
Регистрация: 17.12.2014
Сообщений: 156
03.05.2020, 18:45  [ТС]
Нет, нужно первый. Нужно чтобы при открытии вложенного списка открывался только он, а не вложенный во вложенный тоже. Сейчас у меня при нажатии просто все списки сразу раскрываются, даже учитывая что изначально в стилях скрыто
0
 Аватар для Soldado
901 / 833 / 198
Регистрация: 28.06.2012
Сообщений: 1,607
Записей в блоге: 4
03.05.2020, 19:18
Ну так и ест с :first

Добавлено через 7 минут
Добавил чуток смесей. Сначала открывается первый уровень
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
<ul class="category" id="category_id">
        <li><a>Стройматериалы</a>
            <ul>
            <li><a>Гипсокартонные системы</a>
                <ul>
                <li><a href="">Гипсокартонный лист (ГКЛ)</a></li>
                <li><a href="">Гипсоволокнистый лист (ГВЛ)</a></li>
                <li><a href="">Гипсофибровый лист (ГФЛ)</a></li>
                <li><a href="">Стекломагниевый лист (СМЛ)</a></li>
                <li><a href="">Аквапанели</a></li>
                <li><a href="">Профиль для гипсокартона</a></li>
                <li><a href="">Элементы крепления</a></li> 
                </ul>
           </li>
            <li><a>Сухие смеси</a>
            <ul>
                <li><a href="">1.Сухие смеси</a></li>
                <li><a href="">2.Сухие смеси</a></li>
                <li><a href="">3.Сухие смеси</a></li>
                <li><a href="">4.Сухие смеси)</a></li>
                <li><a href="">5.Сухие смеси</a></li>
                <li><a href="">6.Сухие смеси</a></li>
                <li><a href="">7.Сухие смеси</a></li> 
                </ul>
            
            
            
            </li>
            <li><a href="">Фасадные системы</a></li>
            <li><a href="">Теплоизоляция</a></li>
            <li><a href="">Гидроизоляция</a></li>
            <li><a href="">Звукоизоляция</a></li>
            <li><a href="">Изоляционные пленки</a></li>
            <li><a href="">Кровля</a></li>
            <li><a href="">Общестроительные материалы</a></li>
            <li><a href="">Пиломатериалы</a></li>  
            <li><a href="">Древесно-плитные материалы</a></li>  
            <li><a href="">Пены, герметики, клеи</a></li>  
            <li><a href="">Крепеж</a></li>    
            <li><a href="">Хозяйственный инвентарь</a></li>       
            </ul>
        </li>
        <li><a href="">Отделочные материалы</a></li>
        <li><a href="">Сантехника, отопление и водоснабжение</a></li>
        <li><a href="">Электрика и освещение</a></li>
        <li><a href="">Геоматериалы</a></li>
        <li><a href="">Инструмент и оборудование</a></li>
        <li><a href="">Дача и сад</a></li>  
        </ul>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
$('#category_id > li > a').click(function() {
    
    if ($(this).parent().find('ul').length) {       
      $(this).parent().find('ul:first').slideToggle(200); 
 
      return false;
    }
 
  });
 
 
 $('#category_id > li > ul > li a').click(function() {
       if ($(this).parent().find('ul').length) {        
      $(this).parent().find('ul').slideToggle(200); 
 
      return false;
 
  };
 
});
0
2 / 2 / 0
Регистрация: 17.12.2014
Сообщений: 156
03.05.2020, 19:23  [ТС]
Прошу прощения, мой косяк. Сперва попробовал Ваш вариант и все осталось по-прежнему.
Подвел кэш, не обновилось толком.
Спасибо большое, все заработало
0
2 / 2 / 0
Регистрация: 17.12.2014
Сообщений: 156
03.05.2020, 19:25  [ТС]
Помогли сделать, но исправляли не css а jq, так что наверное не по теме будет. Ну anyway оставлю тут, может пригодится кому
Заменить селектор в 4 строке js на
JavaScript
1
$(this).parent().find('ul:first').slideToggle(200);
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.05.2020, 19:25
Помогаю со студенческими работами здесь

Раскрывающиеся списки
Здраствуйте... В последний раз вас побеспокою) У меня тут такая проблема... Необходимо в ячейку таблицу вставить раскрывающийся...

Раскрывающиеся списки
Здравствуйте, уважаемые форумчане. Возникла проблема. Есть 2 раскрывающихся списка, содержимое которых получено из базы данных, но один из...

Зависимые раскрывающиеся списки
Здраствуйте! У меня такой вопрос: можно ли создать 2 или более раскрывающихся списков, значения каждого из которых зависит от...

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

Поисковый робот и раскрывающиеся списки.
На сайте есть раскрывающийся список но я заметил что эти страницы в индекс поисковика не попадают. Я их добавил в sitemap но результата...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru