html — Не работает выпадающее меню через CSS (hover)
Задать вопрос
Вопрос задан
Изменён 1 год 11 месяцев назад
Просмотрен 304 раза
Я только начала учиться, уже возникают небольшие проблемки:( Уже все перепробовала и перепроверила, не появляется выпадающее меню при наведении. Делала по уроку.
.root { list-style-type: none; display: inline-block; position: relative; padding: 10px 15px; background-color: #ccc; cursor: pointer; } .root:hover { position: relative; display: inline-block; background-color: aqua; } .root:hover .dropdown { display: block; // Вот тут не работает background-color: #ccc; } . dropdown { display: none; position: absolute; top: 54px; left: 48px; box-sizing: border-box; background-color: aquamarine; padding: 10px; width: 100%; } .dropdown>li { cursor: pointer; list-style: none; } .dropdown>li:hover { color: aqua; }
<body> <ul> <li>Меню</li> <ul> <li>1-й элемент</li> <li>2-й элемент</li> </ul> <li>Меню 2</li> <ul> <li>3-й элемент</li> <li>4-й элемент</li> </ul> </ul> </body>
- html
- css
- меню
- hover
2
Нужно было вложить .dropdown
в .root
.root { list-style-type: none; display: inline-block; position: relative; padding: 10px 15px; background-color: #ccc; cursor: pointer; } .root:hover { position: relative; display: inline-block; background-color: aqua; } . root:hover .dropdown { display: block; background-color: #ccc; } .dropdown { display: none; position: absolute; top: 54px; left: 48px; box-sizing: border-box; background-color: aquamarine; padding: 10px; width: 100%; } .dropdown>li { cursor: pointer; list-style: none; } .dropdown>li:hover { color: aqua; }
<body> <ul> <li>Меню <ul> // .dropdown находится внутри .root <li>1-й элемент</li> <li>2-й элемент</li> </ul> </li> <li>Меню 2 <ul> <li>3-й элемент</li> <li>4-й элемент</li> </ul> </li> </ul> </body>
2
Зарегистрируйтесь или войдите
Регистрация через Google
Регистрация через Facebook
Регистрация через почту
Отправить без регистрации
Почта
Необходима, но никому не показывается
Отправить без регистрации
Почта
Необходима, но никому не показывается
Нажимая на кнопку «Отправить ответ», вы соглашаетесь с нашими пользовательским соглашением, политикой конфиденциальности и политикой о куки
Выпадающее меню с поиском на CSS3 и HTML
Никита Киселев
В этой статье я покажу как с помощью CSS3 и HTML5 создать красивое выпадающее меню с полем поиска.
Подготовка
Разработка меню будет вестись в песочнице codepen. В качестве CSS препроцессора используется SCSS. Так же, активированы автоматические преффиксы autoprefixer, что позволяет сосредоточиться только на разработке и не отвлекаться на ручное добавление преффиксов к свойствам, которые ещё не добавлены в спецификацию браузеров.
Для иконок будем использовать FontAwesome.
На этом подготовка завершена. Начнём с продумывания HTML кода.
HTML
Навигационное меню будет представлять собой несортированный список с классом .navigation
, в котором будут различные типы элементов:
- Обычная ссылка
- Форма поиска
- Выпадающее меню
<nav> <ul> <li> <a href="#"> <i></i> </a> </li> <li><a href="#">Приложение</a></li> <li><a href="#">Статистика</a></li> <li> <form> <input type="search" placeholder="Введите фразу для поиска..." /> <button> <i></i> </button> </form> </li> <li> <a href="#"> Опции <i></i> </a> <ul> <li><a href="#">Настройки</a></li> <li><a href="#">Приложение</a></li> <li><a href="#">Статистика</a></li> <li><a href="#">Заказы</a></li> </ul> </li> </ul> </nav>
CSS стили
Пройдёмся по основным моментам в верстке. Весь код вы можете посмотреть в codepen: https://codepen.io/nikitakiselev/pen/JKWvPR.
Flexbox
Для того чтобы все элементы списка .navigation
отображались в строку используем новое CSS свойство display: flex
:
.navigation { display: flex; }
Теперь, все дочерние элементы li
будут выводиться в строку.
Выпадающее меню
Меню сделано только средствами CSS3. У этого способа есть свои недостатки, но из-за своей простоты используем именно его.
В CSS3 есть замечательное свойство transition, которе позволяет сделать изменение некоторых CSS свойств у элемента плавным.
По умолчанию меню должно быть скрыто. Это можно сделать с помощью display: none
, но transition не анимирует это свойство, т.к. у него нет числового значения начального и конечного состояния. На помощь приходит свойство opacity: 0
, которое делает элемент полностью прозрачным.
.subnav { opacity: 0; transition: opacity .3s; } li:hover .subnav { opacity: 1; }
Но тут есть одна проблема. Если у элемента нулевая прозрачность, это ещё не значит что его не существует, поэтому все события для него будут работать, например клик мышкой по ссылкам. Чтобы этого избежать есть свойство pointer-events.
.subnav { opacity: 0; pointer-events: none; transition: opacity . 3s; } li:hover .subnav { opacity: 1; pointer-events: all; }
Цвет placeholder
Чтобы изменить цвет placeholder’ов использовалась вот такая конструкция:
::-webkit-input-placeholder { color: white; } :-moz-placeholder { color: white; } ::-moz-placeholder { color: white; } :-ms-input-placeholder { color: white; }
Сейчас, для простоты она размещена прямо в главном css файле, но в более серьёзным проектах мы вынесем это в миксины. Mixin — это что-то типа функции в php, только для SASS и LESS.
Демо пример
See the Pen Drop-down menu with search on CSS3 and HTML5 by nikitakiselev (@nikitakiselev) on CodePen.Теги: CSS HTML
Please enable JavaScript to view the comments powered by Disqus.html — как оставить раскрывающееся меню открытым при нажатии на всплывающее модальное окно в начальной загрузке 3.
3.7 с ванильным javascriptУ меня есть кнопка внутри раскрывающегося меню, и эта кнопка открывает всплывающее модальное окно. но когда я нажимаю внутри модального содержимого, раскрывающееся меню закрывается. как оставить раскрывающееся меню открытым, когда я нажимаю внутри модального содержимого? но мне нужно, чтобы раскрывающееся меню закрывалось, когда я нажимаю на другой элемент, кроме модального всплывающего окна.
вот мой код (jsfiddle)
<голова> голова> <тело> <дел>Раскрывающиеся списки
Класс .dropdown используется для обозначения раскрывающегося меню.
Используйте класс . dropdown-menu для создания раскрывающегося меню.
Чтобы открыть раскрывающееся меню, используйте кнопку или ссылку с классом .dropdown-toggle и data-toggle="dropdown".
<дел>