Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.95/21: Рейтинг темы: голосов - 21, средняя оценка - 4.95
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363

Показать/скрыть содержимое списка/подсписка

11.07.2021, 21:19. Показов 4046. Ответов 4

Студворк — интернет-сервис помощи студентам
Здравствуйте !
Как показать или скрыть всех дочек элемента списка li ?

Спасибо за помощь и советы

Добавлено через 47 секунд
Пожалуйста, без JQuery
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.07.2021, 21:19
Ответы с готовыми решениями:

Кнопка показать / скрыть содержимое блока вместе с HTML разметкой
Всем привет! Не знаю как правильно объяснить. На сайте sravni.ru/kredity/?rating=any есть таблица на DIV-ах с предложениями банков....

показать полностью\скрыть
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>js18</title> <link rel="stylesheet" type="text/css"...

Показать / скрыть изображение по клику
Привет всем!) Помогите пожалуйста доработать скрипт. Сделал скрипт, он при клике по <code> отображает и скрывает изображение, но...

4
 Аватар для klyapa
3503 / 1267 / 429
Регистрация: 24.07.2016
Сообщений: 1,890
11.07.2021, 22:05
JavaScript
1
2
3
4
const childLi = document.querySelectorAll('li > *');
 
childLi.forEach(elem => elem.style.visibility = 'hidden'); // скрыть
childLi.forEach(elem => elem.style.visibility = 'visible'); // показать
0
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
12.07.2021, 02:13  [ТС]
Лучший ответ Сообщение было отмечено amr-now как решение

Решение

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
<ul>
   <li>Номер 1</li>
       <ul>
           <li>Номер 1-1</li>
           <li>Номер 1-2</li>
       </ul>
   <li>Номер 2</li>
       <ul>
           <li>Номер 2-1</li>
           <li>Номер 2-2</li>
       </ul>
</ul>
При клике на li нужно либо показывать ее деток, если они не видны, либо - наоборот, - прятать

Добавлено через 3 минуты
Т.е. если клик на 'Номер 1", то показывать "Номер 1-1" и "Номер 1-2", если они были спрятаны, либо прятать, если были видны.
Пункт "Номер 2" при этом остается неизменным

Добавлено через 2 минуты
Я это делал раньше, причем не единожды. Там не нужно перебирать деток, - все управляется в самом li.
Но как - забыл и не могу найти

Добавлено через 58 секунд
Что-типа Collapse и Expand

Добавлено через 57 минут
Разобрался. Все оказалось предельно просто:

JavaScript
1
2
3
4
   function clicktree(event) {
    var ul = event.target.querySelector("ul");
    if (ul != null)  ul.hidden = !ul.hidden;
   }
1
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
12.07.2021, 07:18
Лучший ответ Сообщение было отмечено amr-now как решение

Решение

MsGuns, идея очень хорошая.
Уточню реализацию.
Непосредственно внутри <li> отсутствуют вложенные <ul>
В данном случае они могут быть следующим элементом после кликнутого <li> или отсутствовать:
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
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
</head>
<body>
    <ul>
        <li>Номер 1</li>
        <ul>
            <li>Номер 1-1</li>
            <li>Номер 1-2</li>
        </ul>
        <li>Номер 2</li>
        <ul>
            <li>Номер 2-1</li>
            <li>Номер 2-2</li>
        </ul>
    </ul>
    <script>
        let ul = document.querySelector("ul"); // Общий контейнер
        ul.onclick = clicktree;
 
        function clicktree(event) {
            var ul = event.target.nextElementSibling;
            if (ul && ul.tagName === "UL") ul.hidden = !ul.hidden;
        }
    </script>
</body>
</html>
1
1497 / 1238 / 245
Регистрация: 04.04.2011
Сообщений: 4,363
12.07.2021, 12:11  [ТС]
Цитата Сообщение от amr-now Посмотреть сообщение
Уточню реализацию.
Весьма уместное уточнение, т.к. в приведенном мною выше примере код не работает и пришлось <ul> вкладывать в <li>
HTML5
1
2
3
4
5
6
7
<ul>
   <li> Номер 1
      <ul> 
           <li> Номер 1.1</li>
       </ul>
   </li>
</ul>
Добавлено через 1 минуту
В моем случае список строится динамически js из полученного json, поэтому ul оказывается внутри li
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.07.2021, 12:11
Помогаю со студенческими работами здесь

Показать скрыть элемент на JavaScript
Добрый день! В интернете нашел пример скрипта, который показывает и скрывает элементы независимо друг от друга. .collapsible...

Скрыть/показать несколько блоков одной кнопкой
Здравствуйте. Не подскажите, как скрыть/показать сразу несколько блоков одной кнопкой? &lt;div...

Показать/скрыть элемент при клике на checkbox с одинаковыми id
Доброго времени суток друзья. У меня есть много div элементов с одинаковым классом, я хочу их сортировать (показывать / скрывать) с помощью...

Скрыть, показать объект по клику, когда много блоков
Создал сетку GRID и столкнулся с двумя проблемами. 1) Когда внутри блока GRID создаю еще один блок с классом, то он выводится на экран...

Показать/скрыть элемент при клике на checkbox с одинаковыми id
Доброго времени суток друзья. У меня есть много div элементов с одинаковым классом, я хочу их сортировать (показывать / скрывать) с...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru