Categories: CSS стили

Вертикальное меню на css + выпадающий список

Хотел сделать вертикальное меню. При чем хотелось именно на css, а не на яве или флеш. Привожу рабочий вариант + бонус: выпадающий список в этом же меню.
Тем, кому не нужен выпадающий список, может использовать только первые два блока. Ну обо всем по порядку.
Вначале нужно знать, что мы хотим. Мне нужно было меню, где буквы одна под одной, то  есть вертикальное меню. Я перепробовал 8-9 вариантов и самым лучшим оказалось использовании white-space: pre;

Вот код css:

.menop {
color: #fff;
white-space: pre;
float: left;
width: 25%;
background: #ADACAC;
border: 1px solid #fff;
padding-left: 5%;
margin-right: 10%;
min-height:385px;
}

.menop:hover {
background: #FCD3D3;
border: 1px solid #FAF71D;
color: #540E0E;
}

.menop ul li a{
color: #fff;
display:block;
text-decoration: none;
width: 100%;
border-bottom: #540E0E;
}
.menop ul li a:hover{
display:block;
text-decoration: none;
width: 100%;
color: #540E0E;
}
.menop ul {
list-style: none;
margin: 0;
padding: 0;
}
.menop ul li {
position: relative;
}
.menop ul li ul li a {
display: block;
border: 1px solid #000;
background: #ADACAC;
padding: 5px;
text-decoration: none;
color: #fff;
margin: 0;
padding: 5px;
border-radius: 5px;
}
.menop ul li ul li a:hover {
display: block;
border: 1px solid #E23131;
background: #ADACAC;
padding: 5px;
text-decoration: none;
border-radius: 8px;
}
.menop li ul {
display: none;
left: 35px;
position: absolute;
top: 0;
}
.menop li:hover ul {
display: block;
text-decoration: none;
}

 

Для красивого горизонтального меню на несколько позиций достаточно первых двух блоков. Остальное уже для выпадающего меню.
И собственно html-код для примера:

<a href="/koro/">
<div class="menop" style="min-height:270px;">
г
л
а
в
н
а
я
</div></a>

<div class="menop" style="min-height:270px;"><ul><li><a href="/koro/dizajn/">
д
и
з
а
й
н
</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></ul>
</div>

<a href="koro/o-nas/">
<div class="menop" style="min-height: 458px">
о

н
а
с
</div></a>

<div class="menop" style="min-height: 458px"><ul><li><a href="/koro/">
с
т
и
л
и

в

д
и
з
а
й
н
е
</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>
</div>
<a href="/koro/prajs/">
<div class="menop">
у
с
л
у
г
и

и

ц
е
н
ы
</div></a>
<a href="/arhitektura/">
<div class="menop">
а
р
х
и
т
е
к
т
у
р
а
</div></a>

 

Собственно и все. Пример можно глянуть в jsfidle — _http://jsfiddle.net/prolisk/eoydxdun/1/
Вот картинка того, что получается:

Вертикальное меню и выпадающий список на css
veniamin

Recent Posts

Как заработать токен NOT за стейкинг BNB или FDUSD

Очень много разговоров в последнее время за токен NOT. Много бирж будут делать листинг токена,…

6 месяцев ago

Как заработать TON и NOT за стейкинг в телеграм

Телеграм недавно запустил возможность стейкать (замораживать) USDT и получать за это их валюту TON. Очень…

6 месяцев ago

Бонус 100 USDT +10 BUSD от Binance

Биржа криптовалют Binance проводит сейчас промо-акцию: новым пользователям дают ваучеры в сумме 110 долларов. Деньги…

3 года ago

Как парсить длительность видео youtube на php в привычном виде

Самый главный момент в работе с youtube - это получить ключ api через консоль разработчика…

3 года ago

Как удалить чужую сессию пользователя в ubuntu (linux)

Арендую сервер для небольшого проекта на python. И вот приходит мне уведомление, что за сутки…

3 года ago

Как наложить watermark на видео в python windows массово

Тестирую одну схему, и нужно на много видео наложить watermark. Решил делать через Python 3,…

3 года ago