Как сделать многоуровневое меню-аккордион на CSS3.
Всем привет! В этой статье мы рассмотрим, как сделать простое многоуровневое меню-аккордион на CSS3.
Создание структуры
Структура очень простая: аккордион – это ненумерованный список. Если элемент списка содержит другие элементы, тогда мы вставляем input[type=checkbox] и его метку. Также мы добавляем .has-children класс к элементу списка. Все "обычные" элементы списка содержат только ссылку.
<ul class="cd-accordion-menu">
<li class="has-children">
<input type="checkbox" name ="group-1" id="group-1" checked>
<label for="group-1">Group 1</label>
<ul>
<li class="has-children">
<input type="checkbox" name ="sub-group-1" id="sub-group-1">
<label for="sub-group-1">Sub Group 1</label>
<ul>
<li><a href="#0">Image</a></li>
<li><a href="#0">Image</a></li>
<li><a href="#0">Image</a></li>
</ul>
</li>
<li><a href="#0">Image</a></li>
<li><a href="#0">Image</a></li>
</ul>
</li>
<li><a href="#0">Image</a></li>
<li><a href="#0">Image</a></li>
</ul> <!-- cd-accordion-menu -->
Добавляем стили
Мы используем умную(и достаточно стандартную в наши дни) технику определения клика и показываем подсодержание с использованием только CSS: для checkbox элемента мы можем использовать псевдо-класс :checked и смежный селектор(div + div), чтобы изменить свойство display для ul с none на block.
Шаг за шагом: прежде всего, мы должны убедиться, что checkbox охватывает весь элемент списка, который содержит подсодержание. Другими словами, мы должны создать кастомный checkbox. Итак, для начала вы должны проверить, когда кликаете по метке, выбран checkbox или нет. Этого можно достичь, используя for аттрибут внутри элемента метки. Таким образом вы можете просто скрыть input элемент и работать вместо него с меткой.
.cd-accordion-menu input[type=checkbox] {
/* hide native checkbox */
position: absolute;
opacity: 0;
}
.cd-accordion-menu label, .cd-accordion-menu a {
position: relative;
display: block;
padding: 18px 18px 18px 64px;
background: #4d5158;
box-shadow: inset 0 -1px #555960;
color: #ffffff;
font-size: 1.6rem;
}
Заметьте, что сейчас в html разметке input, метка и ненумерованный лист являются родственными элементами. Используя псевдокласс :checked, вы можете анимировать данный процесс: когда checkbox выбран(кликнули по метке), тогда свойство display для элемента ul меняется с none на block.
.cd-accordion-menu ul {
/* by default hide all sub menus */
display: none;
}
.cd-accordion-menu input[type=checkbox]:checked + label + ul,
.cd-accordion-menu input[type=checkbox]:checked + label:nth-of-type(n) + ul {
/* use label:nth-of-type(n) to fix a bug on safari (<= 8.0.8) with multiple adjacent-sibling selectors*/
/* show children when item is checked */
display: block;
}
Если вы хотите сделать плавную анимацию, тогда подключите js файл. Также не забудьте добавить .animate класс к .cd-accordion-menu элементу(это анимирует стрелочки).
Источник: https://codyhouse.co/gem/css-multi-level-accordion-menu/
Итак, на этом все. Спасибо за внимание!
-
- Михаил Русаков
Комментарии (1):
Подскажи пожалуйста, почему когда я делаю фон сайта градиентом, он у меня разбивает весь градиент на полосы?
Ответить
Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.