Горизонтальное выпадающее меню

Горизонтальное выпадающее меню используется для упорядочения структуры навигации по сайту. Оптимальное количество уровней вложения — один-два. Чем меньше уровней вложений, тем легче посетителю сайта найти нужную информацию. Как создать обычное горизонтальное меню, подробно изложено в этом уроке.

Как сделать горизонтальное выпадающее меню

1. HTML-разметка и базовые стили для выпадающего меню с одним уровнем вложения

HTML-разметка горизонтального выпадающего меню отличается от обычного меню тем, что к нужному элементу списка <li> добавляется вложенный список <ul> или <оl>.

Для позиционирования вложенного меню относительно основного меню объявляются следующие стили:
— для элемента списка, в который вложен выпадающий список: li {position: relative;};
— для выпадающего меню ul {position: absolute;}, а также значения left и top.

Для наглядности и удобства форматирования добавим основному меню класс topmenu, выпадающему — submenu.

Скрыть выпадающее меню можно несколькими способами:
1) display: none;
2) overflow: hidden;
3) opacity: 0;
4) transform: scaleY(0);
5) с помощью библиотеки jQuery.

See the Pen MaObbz by Elena Nazarova (@nazarelen) on CodePen.

Способ 1. {display: none;}

Выпадающее меню скрывается с помощью .submenu {display: none;}, при наведении показывается с помощью .topmenu li:hover .submenu {display: block;}.

Способ 2. {visibility: hidden;}

Меню скрывается с помощью .submenu {visibility: hidden;}, показывается — .topmenu li:hover .submenu {visibility: visible;}.

Способ 3. {opacity: 0;}

Меню скрывается с помощью .submenu {opacity: 0;}, показывается — .topmenu li:hover .submenu {opacity: 1;}. Чтобы меню не появлялось при наведении на область, где оно расположено, добавляем visibility: hidden;, а при наведении меняем на visibility: visible;.

Способ 4. {transform: scaleY(0);}

Меню скрывается с помощью .submenu {transform: scaleY(0);}, показывается — .topmenu li:hover .submenu {transform: scaleY(1);}. Поскольку трансформация элемента по умолчанию происходит из центра, нужно добавить для .submenu {transform-origin: 0 0;}, т.е. из верхнего левого угла.

Способ 5. С помощью jQuery

$(".five li ul").hide(); // скрываем выпадающее меню
$(".five li:has('.submenu')").hover(
  function(){
  $(".five li ul").stop().fadeToggle(300);} /* отбираем элемент списка, который содержит элемент с классом .submenu и добавляем ему функцию при наведении, которая показывает и скрывает выпадающее меню */
);

2. 3D выпадающее меню

Интересные эффекты можно создавать с помощью CSS3-трансформаций, например, заставить меню появляться из глубины экрана.

See the Pen OyjVJZ by Elena Nazarova (@nazarelen) on CodePen.

<nav>
  <ul class="topmenu">
    <li><a href="">Home</a></li>
    <li><a href="">Shop</a></li>
    <li><a href="" class="down">Blog</a>
      <ul class="submenu">
        <li><a href="">Category</a></li>
        <li><a href="">Author</a></li>
        <li><a href="">Archive</a></li>
        <li><a href="">Tags</a></li>
      </ul>
    </li>
    <li><a href="" class="down">Portfolio</a>
      <ul class="submenu">
        <li><a href="">Category</a></li>
        <li><a href="">Author</a></li>
        <li><a href="">Archive</a></li>
        <li><a href="">Tags</a></li>
      </ul>
    </li>
    <li><a href="">Contact</a></li>
  </ul>
</nav>
* {box-sizing: border-box;}
body {
  margin: 0;
  background: radial-gradient(#BFD6E2 1px, rgba(255,255,255,0) 2px);
  background-size: 10px 10px;
}
nav ul {
  list-style: none;
  margin: 0px;
  padding: 0px;
}
nav a {
  text-decoration: none;
  outline: none;
  display: block;
}
.topmenu {
  backface-visibility: hidden;
  background: rgba(255,255,255,.8);
}
.topmenu:after {
  content: "";
  display: table;
  clear: both;
}
.topmenu > li {
  display: inline-block;
  position: relative;
}
.topmenu > li > a {
  font-family: 'Exo 2', sans-serif;
  height: 70px;
  line-height: 70px;
  padding: 0 30px;
  font-weight: bold;
  color: #003559;
  text-transform: uppercase;
  transition: .4s ease-in-out;
}
.down:after {
  content: "\f107";
  margin-left: 8px;
  font-family: FontAwesome;
}
.topmenu > li > a:hover {color: #E6855F;}
.submenu {
  background: white;
  border: 2px solid #003559;
  position: absolute;
  left: 0;
  visibility: hidden;
  opacity: 0;
  z-index: 5;
  width: 150px;
  transform: perspective(600px) rotateX(-90deg);
  transform-origin: 0% 0%;
  transition: .6s ease-in-out;
}
.topmenu > li:hover .submenu{
  visibility: visible;
  opacity: 1;
  transform: perspective(600px) rotateX(0deg);
}
.submenu li a {
  color: #7f7f7f;
  font-size: 13px;
  line-height: 36px;
  padding: 0 25px;
  font-family: 'Kurale', serif;
}
.submenu li a:hover {color: #E6855F;}

3. Разворачивающееся выпадающее меню с логотипом

В этом примере в верхнем разделе страницы расположены логотип и навигация по сайту. В качестве логотипа может быть картинка или текст. Выпадающее меню постепенно разворачивается из-под элемента верхнего списка с помощью функции CSS3-трансформации.

See the Pen vXBBaa by Elena (@html5book) on CodePen.

<header>
  <a href="" class="logo">Лого</a>
  <nav>
      <ul class="topmenu">
        <li><a href="">Главная</a></li>
        <li><a href="" class="submenu-link">О нас</a>
          <ul class="submenu">
            <li><a href="">Производство</a></li>
            <li><a href="">Магазин</a></li>
            <li><a href="">Сервис</a></li>
          </ul>
        </li>
        <li><a href="">Проекты</a></li>
        <li><a href="">Контакты</a></li>
      </ul>
    </nav>
</header>
* {box-sizing: border-box;}
body {
  margin: 0;
  background: #f2f2f2;
}
header {
  background: white;
  text-align: center;
}
header a {
  text-decoration: none;
  outline: none;
  display: block;
  transition: .3s ease-in-out;
}
.logo {
  color: #D5B45B;
  font-family: 'Playfair Display', serif;
  font-size: 2.5em;
  padding: 20px 0;
}
nav {
  display: table;
  margin: 0 auto;
}
nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.topmenu > li {
  width: 25%;
  float: left;
  position: relative;
  font-family: 'Open Sans', sans-serif;
}
.topmenu > li > a {
  text-transform: uppercase;
  font-size: 14px;
  font-weight: bold;
  color: #404040;
  padding: 15px 30px;
}
.topmenu > li:hover > a, .submenu li:hover a {color: #D5B45B;}
.submenu-link:after {
  content: "\f107";
  font-family: "FontAwesome";
  color: inherit;
  margin-left: 10px;
}
.submenu {
  background: #273037;
  position: absolute;
  left: 0;
  top: 100%;
  z-index: 5;
  width: 180px;
  opacity: 0;
  transform: scaleY(0);
  transform-origin: 0 0;
  transition: .5s ease-in-out;
}
.submenu a {
  color: white;
  text-align: left;
  padding: 12px 15px;
  font-size: 13px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.submenu li:last-child a {border-bottom: none;}
.topmenu > li:hover .submenu {
  opacity: 1;
  transform: scaleY(1);
}

4. Увеличивающееся выпадающее меню

Ещё один пример для выпадающего меню. Эффект увеличения при появлении меню реализуется за счет уменьшения первоначального размера .submenu {transform: scale(.8);}, при наведении размер увеличивается до .topmenu > li:hover .submenu {transform: scale(1);}.

See the Pen aNbGKv by Elena Nazarova (@nazarelen) on CodePen.

<nav>
  <ul class="topmenu">
    <li><a href="">Home</a></li>
    <li><a href="">Shop</a></li>
    <li><a href="">Blog</a>
       <ul class="submenu">
    <li><a href="">Category</a></li>
     <li><a href="">Author</a></li>
     <li><a href="">Archive</a></li>
     <li><a href="">Tags</a></li>
     </ul>
    </li>
    <li><a href="">Portfolio</a>
      <ul class="submenu">
    <li><a href="">Category</a></li>
     <li><a href="">Author</a></li>
     <li><a href="">Archive</a></li>
     <li><a href="">Tags</a></li>
     </ul>
    </li>
    <li><a href="">Contact</a></li>
  </ul>
</nav>
* {box-sizing: border-box;}
body {
  margin: 0;
  background: url(https://html5book.ru/wp-content/uploads/2015/10/background54.png)
}
nav {background: white;}
nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
nav a {
  text-decoration: none;
  outline: none;
  display: block;
  transition: .4s ease-in-out;
}
.topmenu {
  text-align: center;
  padding: 10px 0;
}
.topmenu > li {
  display: inline-block;
  position: relative;
}
.topmenu > li:after {
  content: "";
  position: absolute;
  right: 0;
  width: 1px;
  height: 12px;
  background: #d2d2d2;
  top: 16px;
  box-shadow: 4px -2px 0 #d2d2d2;
  transform: rotate(30deg);
}
.topmenu > li:last-child:after {
  background: none;
  box-shadow: none;
}
.topmenu > li > a {
  padding: 12px 26px;
  color: #767676;
  text-transform: uppercase;
  font-weight: bold;
  letter-spacing: 1px;
  font-family: 'Exo 2', sans-serif;
}
.topmenu > li:hover > a {color: #c0a97a;}
.submenu {
  position: absolute;
  left: 50%;
  top: 100%;
  width: 210px;
  margin-left: -105px;
  background: #fafafa;
  border: 1px solid #ededed;
  z-index: 5;
  visibility: hidden;
  opacity: 0;
  transform: scale(.8);
  transition: .4s ease-in-out;
}
.submenu li a {
  padding: 10px 0;
  margin: 0 10px;
  border-bottom: 1px solid #efefef;
  font-size: 12px;
  color: #484848;
  font-family: 'Kurale', serif;
}
.topmenu > li:hover .submenu {
  visibility: visible;
  opacity: 1;
  transform: scale(1);
}
.submenu li a:hover {color: #c0a97a;}

5. Подъезжающее выпадающее меню

Горизонтальное меню с мини-анимацией: при наведении на ссылки верхнего меню появляется маленький кружок, который также сопровождает появление выпадающего меню.

See the Pen MpqypG by Elena Nazarova (@nazarelen) on CodePen.

<nav>
  <ul class="topmenu">
    <li><a href="">Home</a></li>
    <li><a href="">Shop</a></li>
    <li><a href="" class="down">Blog</a>
      <ul class="submenu">
        <li><a href="">Category</a></li>
        <li><a href="">Author</a></li>
        <li><a href="">Archive</a></li>
        <li><a href="">Tags</a></li>
      </ul>
    </li>
    <li><a href="" class="down">Portfolio</a>
      <ul class="submenu">
        <li><a href="">Category</a></li>
        <li><a href="">Author</a></li>
        <li><a href="">Archive</a></li>
        <li><a href="">Tags</a></li>
      </ul>
    </li>
    <li><a href="">Contact</a></li>
  </ul>
</nav>
@import url('https://fonts.googleapis.com/css?family=Kaushan+Script|Libre+Baskerville');
body {
  margin: 0;
  background-image: url(https://html5book.ru/wp-content/uploads/2017/03/dulcineia-dias-195000.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  height: 100vh;
  position: relative;
}
body:before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 100%;
  width: 100%;
  background: linear-gradient(45deg, rgba(0,0,0,0), rgba(255,255,255,.8));
}
nav {
  text-align: center;
  padding: 40px 0 0;
}
nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
nav a {
  text-decoration: none;
  display: block;
  color: #222;
}
.topmenu > li {
  display: inline-block;
  position: relative;
}
.topmenu > li > a {
  position: relative;
  padding: 10px 15px;
  font-family: 'Kaushan Script', cursive;
  font-size: 1.5em;
  line-height: 1;
  letter-spacing: 3px;
}
.topmenu > li > a:before {
  content: "";
  position: absolute;
  z-index: 5;
  left: 50%;
  top: 100%;
  width: 10px;
  height: 10px;
  background: white;
  border-radius: 50%;
  transform: translate(-50%, 20px);
  opacity: 0;
  transition: .3s;
}
.topmenu li:hover a:before {
  transform: translate(-50%, 0);
  opacity: 1;
}
.submenu {
  position: absolute;
  z-index: 4;
  left: 50%;
  top: 100%;
  width: 150px;
  padding: 15px 0 15px;
  margin-top: 5px;
  background: white;
  border-radius: 5px;
  box-shadow: 0 0 30px rgba(0,0,0,.2);
  box-sizing: border-box;
  visibility: hidden;
  opacity: 0;
  transform: translate(-50%, 20px);
  transition: .3s;
}
.topmenu > li:hover .submenu {
  visibility: visible;
  opacity: 1;
  transform: translate(-50%, 0);
}
.submenu a {
  font-family: 'Libre Baskerville', serif;
  font-size: 11px;
  letter-spacing: 1px;
  padding: 5px 10px;
  transition: .3s linear;
}
.submenu a:hover {background: #e8e8e8;}
  • Создание Сайтов

    Ну вот, появилась статья, которую ждал. Елена, благодарю, что уделили внимание.

    • Пожалуйста. На самом деле ничего сложного, главное понять принцип создания структуры выпадающего меню и css-стили, без которых эта конструкция не будет существовать.

      • Создание Сайтов

        Пытаюсь сообразить, как его реализовать на вордпресс.

        • Вам нужно выяснить, какие классы и идентификаторы привязаны к имеющемуся меню шаблона и переписать для них стили. Вложенность пунктов: Консоль-Внешний вид-Меню-Структура меню и вкладываете элементы в нужный раздел.

          • Создание Сайтов

            там ведь все идет методом генерации, вот и думаю, как при написании шаблона, привязать такие меню.

          • То есть вы пишите шаблон с нуля? Меню выводится с помощью . Подробно про настройки можно прочитать здесь http://wp-kama.ru/function/wp_nav_menu

          • Создание Сайтов

            Я делаю сайты для частного бизнеса, одностраничники или обычные сайты визитки. Сайт визитка как раз нуждается в простом, красивом и удобном меню. Можно конечно взять готовые темы и переписать их, но это еще заморочней.Куда проще написать с нуля, простую, легкую тему, заточенную под определенные плагины.

            Наверное это то, что мне нужно. Вся суть в том, чтобы меню генерировалось при создании новой страницы подраздела или подкатегории. Благодарю.

          • Меню генерируется автоматически. В консоли Вордпресс вкладка «Внешний вид», далее пункт «Настройки» — устанавливается то или иное меню, в пункт «Меню» оно настраивается. Все страницы после публикации автоматически попадают в «Страницы». Нужно поставить галочку и они добавятся в конструктор меню, а там уже перетаскиваешь блоки в то место, где они должны быть вложены. Также внизу есть пункт «Автоматически добавлять в это меню новые страницы верхнего уровня», там можно тоже галочку поставить.

          • Создание Сайтов

            Это я в курсе. Не доводилось еще писать самостоятельно тему с многоуровневым меню, поэтому есть кое-какие сомнения что субы будут работать корректно.

            Теперь ждем вертикальное выпадающее меню 🙂

          • МишСА

            я буду вам благодарен если будущем вы будете написать темы который очень популярен данный момент!.

          • Создание Сайтов

            Что-то наша красавица приуныла, ничего нового. Каждый день захожу в надежде увидеть новую статью. Но, увы.

          • Не переживайте, со мной все в порядке))) Период идей, пока все на черновиках. Прошу чуточку терпения, на следующей неделе будут новые уроки.

          • Создание Сайтов

            Вот довелось применить это меню на вордпресс, А он с ним не контачит. Вордпресс выводит свои ul и li с другими классами. Пришлось поменять классы под него. А класс fa вообще не знаю как подцепить

          • По поводу узнать классы — смотрите пример во вложении.

            Иконки можно добавлять к элементам списка через свойство content, например:

            li:before {
            content: «f263»; /*код Unicode для выбранной иконки*/
            font-family: «FontAwesome»;
            margin-right: 10px; /*отступ между иконкой и текстом ссылки*/
            display: inline-block;
            color: salmon; /*задаем цвет иконки*/
            font-size: 1.2em; /*устанавливаем размер иконки*/
            }

          • Создание Сайтов

            Не подсвечивается посещаемый раздел.

          • Там должно быть что-то типа .current-menu-item для активного пункта меню.

          • Создание Сайтов

            Это я знаю, просто не мог сначала понять к чему этот класс приписать. Что-то иконки какие-то непонятные там. Наверное файл надо цеплять с ними. Ну их.

          • Зачем же так сразу сдаваться? ))) Разместите <link rel=»stylesheet» href=»https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.4.0/css/font-awesome.css»> внутрь раздела <head>…</head>, и все заработает

          • Alexander V

            Нет ничего хуже, чем адаптировать шаблон под WP, особенно это касается меню. pdoMenu(Modx) в этом плане вне конкуренции.

  • Alexander V

    3-й уровень могли бы сделать. А то многоуровневые превратились в 2-х уровневые.

    • Вы имеете в виду урок по созданию трехуровневых меню? Если так, то в планах есть такой.

  • Александр Нестерюк

    Здравствуйте! Не подскажите как мне реализовать меню ?

    • Подскажу, конечно, но сейчас непонятно, о чём конкретно идёт речь.

  • Создание Сайтов

    Так до сих пор и не понял, как класс FA и другой который там же, можно реализовать на генерируемом меню в LI

  • Создание Сайтов

    нашел этот класс который отвечает за субменю

  • Создание Сайтов

    Вот такого кода не нашел я ни в одном уроке:
    //**Выпадающее меню скрывается с помощью .submenu {display: none;}, при наведении показывается с помощью .topmenu li:hover .submenu {display: block;}

  • Создание Сайтов

    В последнем меню что-то не хватает. Перепробовал и не работает. Выводит меню по центру nav

    Наконец то нашел этот ул на вордпрессе которому в меню можно прописать свой класс. Пробовал меню и некоторые не корректные. Даже напрямую не работают.

    • Все примеры рабочие. Вы можете показать что вы делаете в этом же редакторе CODEPEN, чтобы я проверила, что у вас не так.

  • Сергей Шекин

    дружище привет! меню я смотрю очень много классных. но мне нужно такое меню на ксс без библиотек. чтоб при наведении курсора оно вылазило и пока не нажмешь в нем какую либо кнопку оно не пряталось. люди с планшетами жалуются что не могут перейти никуда. как это сделать? очень благодарен за раннее.

    • Привет! :hover для этого случая не подходит. Сделала пример с :target, посмотрите http://codepen.io/nazarelen/pen/pbkaRj.

      • Сергей Шекин

        Ой девушка извини. у тебя там картинка прописана. а у меня меню на ксс стили вот такие.

        #navbar ul{
        display: none;
        background-color: #00baff;
        position: absolute;
        top: 100%;
        }
        #navbar li:hover ul { display: block; }
        #navbar, #navbar ul{
        margin: 0;
        padding: 0;
        list-style-type: none;
        }
        #navbar {
        height: 30px;
        background-color: #05bada;
        padding-left: 25px;
        min-width: 470px;
        }
        #navbar li {
        float: left;
        position: relative;
        height: 100%;
        }
        #navbar li a {
        display: block;
        padding: 6px;
        width: 100px;
        color: #fff;
        text-decoration: none;
        text-align: center;
        }
        #navbar ul li { float: none; }
        #navbar li:hover { background-color: #00baff; }
        #navbar ul li:hover { background-color: #05bada; }

        я в этом не силен подправь пожалуйста если не тяжело. за раннее очень благодарен.

        • Посмотрите сейчас. Псевдокласс :target воспроизводит клик мыши. Единственный минус данного способа — нельзя перейти по верхней ссылке Blog.
          Если нужно, чтобы выпадающее меню закрывалось при нажатии на любую область на странице, а не только на сами пункты меню, добавьте <a href=»#» class=»close»></a> в любое место на странице вне разметки самого меню.

          • Сергей Шекин

            это не единственный минус данного меню. теперь оно стало неудобным для пользователей которые пользуются мышью прокрутка работает как то не серьезно только первая и последняя кнопка. а те которые в середине проскакивает Леночка, другие варианты меню есть какие не будь? с уважением Сергей.

          • Сергей, я не вижу проблемы пользования мышью. Можно подробнее описать проблему, для чего вы используете прокрутку. Меню показывается при клике мышью, далее спускаемся вниз по меню и выбираем нужный пункт. Если можно, пришлите ссылку на живой пример.

          • Сергей Шекин

            а да извини это меню просто так отображается в твоем примере. нужно использовать прокрутку чтоб увидеть все кнопки. сейчас поставлю на сайт и посмотрю кнопка блог мне не важна главное чтоб кнопки работали после того как меню выпадет. спасибо огромное за помощь.

          • Чтобы сменить вид просмотра, нужно начать на кнопки, которые я выделила на картинке:

          • Сергей Шекин

            да я вроде все правильно прописал а почему оно не корректно скопировалось не могу понять. могу файл скинуть посмотришь что там не правильно? скайп есть? добавься пожалуйста: sergei65612

          • завтра

          • Сергей Шекин

            Леночка ничего не вышло. я прописал HTML вот так

            МОЙ ОФИС

            ПРОФИЛЬ
            ПАРТНЕРКА
            НАСТРОЙКИ

            БАЛАНС

            БОНУС
            ПОПОЛНИТЬ
            ВЫВЕСТИ

            ИГРА

            МАГАЗИН
            СКЛАД
            ОБМЕН
            ЗАПРАВКА

            ЗАРАБОТОК

            СЕРФИНГ
            ПИСЬМА

            РЕКЛАМА

            БАННЕРЫ
            УСЛУГИ

            ВЫХОД

            открывается только первое меню а остальные когда кликаю открывается все равно первое. где ошибка понять не могу. помоги пожалуйста.

          • Название каждого элемента списка должно быть помещено внутрь тега текст ссылки, иначе нет смысла в таком меню, пользователи не смогут переходить по ссылкам, потому что их просто нет. Также обратите внимание на значение атрибута href в ссылке над выпадающим меню в моём примере.

  • павел

    а как сохраняется .topmenu li a:hover при переходе на .submenu

    • вы имеете в виду цвет ссылки? если да, то в каждом примере прописаны отдельные стили для .submenu li a:hover.

  • Alexandr Mironov

    Елена, здравствуйте!

    Помогите, пожалуйста, чайнику 🙂

    Поставил у себя на сайте вот этот пример — 3. Разворачивающееся выпадающее меню с логотипом, но не отображается картинка со стрелочкой, которая находится после пункта -о нас-. Маленькая стрелочка, которая смотрит вниз.

    Вы не могли бы подсказать, где она находится в коде, чтобы я смог туда вставить свою картинку со стрелочкой?

    • Здравствуйте, Александр.
      Эта стрелочка — иконка Шрифт Awesome. В код она добавляется для элемента <a> с помощью свойства content:
      .submenu-link:after {
      content: «f107»;
      font-family: «FontAwesome»;
      color: #404040;
      margin-left: 10px;
      }
      Чтобы поменять ее на картинку, то этот код нужно изменить так:
      .submenu-link:after {
      content: url(http://html5book.ru/wp-content/uploads/2015/02/flower221.png); /* поменяйте на ваш адрес картинки */
      display: inline-block;
      margin-left: 10px;
      }

      • Alexandr Mironov

        content: url(http://html5book.ru/wp-content… /* поменяйте на ваш

        У меня картинка находится в папке сайта.
        Я пытался вот так написать:

        .submenu-link:after {
        content: images/стрелка.png;
        display: inline-block;
        margin-left: 10px;
        }

        Но, наверное, я опять делаю что-то не так(

        • content: url(images/стрелка.png);. Запись url() обязательна, а название картинок лучше писать латинскими буквами, например, strelka.png

  • Аркадий Михалыч

    Спасибо выручили, а то бутстраповское меню чота сложно перепиливается под собственные нужды, слишком стилей левых много в нем)

  • Михаил

    А как увеличить размер текста в выпадающем меню?
    Сделал последний вариант,но шрифт очень мелкий
    Самому разобраться не получается

    • Вам нужно поменять размер шрифта в .submenu li a {}. Там задано font-size: 12px;.

  • Только скриптом. Можно взять какой-нибудь готовый плагин.

  • Irina Pronina

    Добрый вечер,
    во-первых, хочу поблагодарить Вас за чудесный сайт!
    во-вторых, есть вопрос. Выбрала в 1 пункте урока 3-ий вариант, но мне хотелось, чтобы topmenu было по центру страницы (это я сделала добавив .topmenu {text-align: center;} ),
    а выпадающее, чтобы выравнивалось по левому краю. И вот тут я застряла. пробовала все, на что хватило фантазии, идеи кончились =(
    (так же хотелось бы понять как сделать, чтобы блоки выпадающего меню были отделены друг от друга тонкой линией. У Вас в результатах так и есть, но в коде нет. Пыталась добавить border-bottom: 1px solid #fff; в submenu, но тогда эта рамка появляется лишь в самом низу, где уже и не нужна)

    P.S. Надеюсь я понятно изложила свои вопросы и заранее благодарю за ответ

    • Здравствуйте. Чтобы пункты выпадающего меню выравнивались по левому краю, добавьте .submenu {text-align: left;}. Вы также можете задать фиксированную ширину выпадающему меню, заменив .submenu {width: 100%;} на любое значение в пикселях.
      За белую линию отвечает код

      .submenu li a {
          border-bottom: 1px solid rgba(255,255,255,.3);
          color: white;
      }
      • Irina Pronina

        Добрый день, спасибо за ответ. Я уже пробовала .submenu {text-align: left;} но почему то никак страница не реагирует на это изменение.
        тоже самое с линией =( вообще никакой реакции, не понимаю почему. Хотя на изменение параметров, заданных Вами (та же ширина, к примеру) отзывается.

  • Надежда Лагунова

    Подскажите как сделать чтобы один из выпадающих пунктов меню был всегда развернут?

    • Можно добавить дополнительный класс .hidden для скрытого выпадающего меню (посмотрите пример на основе 4-го меню http://codepen.io/html5book/pen/evRvYv) и убрать свойства, скрывающие меню из общего блока объявления для всех подменю .submenu.
      Единственное, в данном случае нужно будет поменять расстояние между ссылками в верхнем меню или уменьшить ширину выпадающего меню, чтобы они не перекрывали друг друга.

  • Olga Maltseva

    Этот сайт просто Клондайк! Подача материала, супер-удобная навигация, радующий глаза дизайн…Огромная благодарность автору!Таким людям нужно грант выдавать, чего и желаю в ближайшем будущем!))

    • Спасибо за тёплые слова! Очень приятно )) Было бы неплохо, если бы что-то подобное произошло 😉

  • Michail Schnittmann

    Уважаемая Елена. Спасибо за ваши разъяснения. Я использовал вариант 2. несколько причесав его под свои нужды. http://www.michail-schnittmann.de/index.html На ПК работает прекрасно, а на айпэде и айфоне (правда старого образца) не работает. Что Вы могли бы посоветовать? С уважением Михаил

    • Какая версия браузера на устройствах?

      • Michail Schnittmann

        пэд — 7.0.4; фон — 7.1.2.

        • В принципе, проблем быть не должно. Единственное, у вас в коде много ошибок.

          • Michail Schnittmann

            в самом html или в css?

          • В разметке страницы, то есть в html-коде. И в скрипте тоже.

          • Michail Schnittmann

            Спасибо большое. Попытаюсь разобраться, хотя надежды мало.