08.02.2018
Вертикальное меню аккордеон на jQuery
					
				
Меню аккордеон или варианты с любым схлопыванием элементов навигации очень полезны для построения древовидных меню с большим количеством элементов. На первый взгляд есть опасения, что такое меню реализовать очень сложно, но для этого уже давно все изобретено и написано куча строк кода.
Но в данной статье мы сделаем свое меню и поймем как оно устроено.
Для начало делаем стандартный древовидный двухуровневый список, см. ниже в коде HTML. Это и будет основой нашего меню.
Затем оборачиваем наше меню в стили, не забывая про 2 состояния .slide и .active, которые показывают, что меню раскрыто или активно в данный момент. Список меню второго уровня сразу скрываем, используя display: none, а для активного состояния display: block, все стандартно.
Далее идет скрипт, который мы активируем при нажатии на ссылку в первом уровне меню. Если подменю данного пункта не видно, тогда закрываем все другие меню
if (false == $(this).next().is(':visible')) {
	menu.find('li').removeClass('slide active');
	menu.find('ul').slideUp();
}
и скрываем/раскрываем выбранное подменю:
$(this).next().slideToggle();
$(this).parent().addClass('slide');
Вот и все, что нам нужно для неплохого меню в виде аккордеона на jQuery.
<ul class="accordeon"> <li> <a href="#">Audi</a> <ul> <li>A3</li> <li>A4</li> <li>A5</li> <li>A6</li> <li>Q3</li> <li>Q5</li> <li>Q7</li> </ul> </li> <li class="active"> <a href="#">BMW</a> <ul> <li>1 Series</li> <li>3 Series</li> <li>5 Series</li> <li>X1</li> <li>X3</li> <li>X5</li> </ul> </li> <li> <a href="#">Mercedes-Benz</a> <ul> <li>A</li> <li>C</li> <li>E</li> <li>S</li> <li>GLA</li> <li>GLC</li> <li>GLE</li> </ul> </li> <li> <a href="#">Volkswagen</a> <ul> <li>Polo</li> <li>Golf</li> <li>Jetta</li> <li>Passat</li> <li>Tiguan</li> <li>Toureg</li> </ul> </li> </ul>
.accordeon,
.accordeon ul {
	margin: 0;
	padding: 0;
	list-style: none;
}
.accordeon li {
	margin: 0 0 2px 0;
	padding: 0;
}
.accordeon > li > a {
	background: #FFF;
	color: #333;
	display: block;
	font-weight: 700;
	height: 50px;
	line-height: 50px;
	padding: 0 30px;
	text-decoration: none;
	text-transform: uppercase;
	vertical-align: middle;
	width: 100%;
}
.accordeon > li.slide > a,
.accordeon > li.active > a {
	background: #1967c3;
	color: #FFF;
}
.accordeon > li > ul {
	display: none;
	width: 100%;
	background: #FFF;
	padding: 10px 0;
}
.accordeon > li.active > ul {
	display: block;
}
.accordeon > li > ul > li {
	padding: 5px 30px;
	text-decoration: none;
	display: block;
	color: #333;
}
								$(".accordeon > li > a").click(function (e) {
	e.preventDefault();
	
	var menu = $(this).closest('.accordeon');
	
	if (false == $(this).next().is(':visible')) {
		menu.find('li').removeClass('slide active');
		menu.find('ul').slideUp();
	}
	
	$(this).next().slideToggle();
	$(this).parent().addClass('slide');
});
								Демонстрация
- 
		Audi
		
- A3
 - A4
 - A5
 - A6
 - Q3
 - Q5
 - Q7
 
 - 
		BMW
		
- 1 Series
 - 3 Series
 - 5 Series
 - X1
 - X3
 - X5
 
 - 
		Mercedes-Benz
		
- A
 - C
 - E
 - S
 - GLA
 - GLC
 - GLE
 
 - 
		Volkswagen
		
- Polo
 - Golf
 - Jetta
 - Passat
 - Tiguan
 - Toureg
 
 
Нам будет приятно
Поделитесь
Комментарии