Jump to content
  • 0

Меню css+html


Dolce
 Share

Question

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

9a27c1310b7b.jpg

Лопатил css, но никак не могу понять как убрать это вот код:


.navTitle{
padding: 10px;
background: #4b9342;
}
.navTitle p{font-size: 16px; font-weight: bold; color: #fff;}
#nav {
margin: 15px 0 10px 10px;
border:2px solid #4b9342;
box-shadow:2px 2px 8px #000000;
border-radius:3px;
-moz-border-radius:3px;
-webkit-border-radius:3px;
}
#nav, #nav ul {
list-style:none;
padding:0;
width:250px;
}
#nav ul {
position:relative;
z-index:-1;
}
#nav li {
position:relative;
z-index:100;
}
#nav ul li {
margin-top:-23px;
-moz-transition: 0.4s linear 0.4s;
-ms-transition: 0.4s linear 0.4s;
-o-transition: 0.4s linear 0.4s;
-webkit-transition: 0.4s linear 0.4s;
transition: 0.4s linear 0.4s;
}
#nav li a {
background-color:#fff;
color:#000;
display:block;
font-size:14px;
font-weight:bold;
line-height:30px;
outline:0;
padding-left:10px;
text-decoration:none;
border-bottom: 1px solid #4b9342;
}

#nav li a img {
border-width:0px;
height:24px;
line-height:28px;
margin-right:8px;
vertical-align:middle;
width:24px;
}
#nav li a:hover {
color: #4b9342;
}
#nav ul li a {
padding-left: 20px;
background-color:#eee;
border-bottom:1px solid #ccc;
color:#000;
font-size:12px;
line-height:22px;
}
#nav ul li a:hover {
background-color:#ddd;
color:#444;
}

#nav a.sub:focus {
color: #4b9342;
outline:0;
}
#nav a:focus ~ ul li {
margin-top:0;
-moz-transition: 0.4s linear;
-ms-transition: 0.4s linear;
-o-transition: 0.4s linears;
-webkit-transition: 0.4s linears;
transition: 0.4s linear;
}
#nav a:focus + img, #nav a:active + img {
display:block;
}
#nav a.sub:active {

outline:0;
}
#nav a:active ~ ul li {
margin-top:0;
}
#nav ul:hover {
display:block;
}

И HTML:


<nav>
<ul id="nav">
<div class="navTitle"><p>Школьные принадлежности</p></div>
<li><a href="#" class="sub" tabindex="1">Бумажно-беловая продукция</a>
<ul>
<li><a href="#">Альбомы для рисования</a></li>
<li><a href="#">Блокноты, записные книжки</a></li>
<li><a href="#">Бумага цветная, картон</a></li>
<li><a href="#">Папки для тетрадей и труда</a></li>
</ul>
</li>
<li><a href="#" class="sub" tabindex="1">Настольные принадлежности</a>
<ul>
<li><a href="#">Глобусы</a></li>
<li><a href="#">Калькуляторы карманные</a></li>
</ul>
</li>
<li><a href="#" class="sub" tabindex="1">Офисные принадлежности и инструменты</a>
<ul>
<li><a href="#">Клей</a></li>
<li><a href="#">Ножницы детские</a></li>
<li><a href="#">Пеналы офисные, боксы</a></li>
</ul>
</li>
<li><a href="#" class="sub" tabindex="1">Принадлежности для делопроизводства</a>
<ul>
<li><a href="#">Папки, портфели пластиковые</a></li>
</ul>
</li>
<li><a href="#" class="sub" tabindex="1">Принадлежности для письма,черчения и рисования</a>
<ul>
<li><a href="#">Карандаши восковые</a></li>
<li><a href="#">Карандаши графитные</a></li>
<li><a href="#">Карандаши механические</a></li>
<li><a href="#">Карандаши пастельные</a></li>
<li><a href="#">Карандаши цветные</a></li>
<li><a href="#">Кисти</a></li>
<li><a href="#">Краски акварельные</a></li>
<li><a href="#">Краски для оформительских работ</a></li>
<li><a href="#">Краски-гуашь</a></li>
</ul>
</li>
<li><a href="#" class="sub" tabindex="1">Рюкзаки, портфели, сумки, пеналы</a>
<ul>
<li><a href="#">Пеналы секционные</a></li>
<li><a href="#">Пеналы-кошельки</a></li>
<li><a href="#">Рюкзаки для младших и средних классов</a></li>
<li><a href="#">Рюкзаки подростковые</a></li>
<li><a href="#">Сумки молодежные</a></li>
</ul>
</li>
<li><a href="#" class="sub" tabindex="1">Товары для творчества</a>
<ul>
<li><a href="#">Доски для письма и рисования</a></li>
<li><a href="#">Наборы для рукоделия</a></li>
<li><a href="#">Наборы для скарпбукинга</a></li>
<li><a href="#">Пластилин</a></li>
<li><a href="#">Пластилин-наборы</a></li>
</ul>
</li>
<li><a href="#" class="sub" tabindex="1">XSLT</a>
<ul>
<li><a href="#">Обложки для книг и тетрадей</a></li>
<li><a href="#">Папки, портфели школьные</a></li>
<li><a href="#">Пеналы, стаканы настольные</a></li>
<li><a href="#">Подставки для книг </a></li>
<li><a href="#">Развиваюшие пособия</a></li>
</ul>
</li>
</ul>
</nav>

Подскажите пожалуйста как это можно поправить?

Link to comment
Share on other sites

6 answers to this question

Recommended Posts

  • 0

вылазит из-за того что предедущий элемент в 2е строки.

если забить на плавность анимации схлопывания то можно так: http://jsfiddle.net/6QpsC/1/

в целом ты пытаешся сделать на чистом CSS то что на сегодняшней день проще сделать на JS. Это обычный аккардеон. работать кроссбраузерно это не будет.

мой совет сделать на JS.

Ну или сменить концепцию. Например зацепится за height: 0; с overflow: hidden;

а при клике height: auto;

не уверен что сработает.

Link to comment
Share on other sites

  • 0

вылазит из-за того что предедущий элемент в 2е строки.

если забить на плавность анимации схлопывания то можно так: http://jsfiddle.net/6QpsC/1/

в целом ты пытаешся сделать на чистом CSS то что на сегодняшней день проще сделать на JS. Это обычный аккардеон. работать кроссбраузерно это не будет.

мой совет сделать на JS.

Ну или сменить концепцию. Например зацепится за height: 0; с overflow: hidden;

а при клике height: auto;

не уверен что сработает.

Спасибо, а не подскажете примеры с js ?

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

 Share

  • Similar Content

    • By Etaro
      Я не понимаю, в чём проблема в вертикальном выпадающем меню. Где я мог напортачить? Нужно сделать, чтобы колонки были по вертикали, а не по горизонтали.


    • By Sve
      Всем привет :)
      Пытаюсь сверстать свой первый макет, и возникла проблема с меню. Должно быть, как на первой картинке - это макет из фш.
      Выходит, как на второй, меню спадает вниз. 
      Прошу, пожалуйста, тыкните на ошибку в коде, и, если есть возможность, объясните. буду очень рада ответам!
      Код кидаю:
      *{margin: 0; padding: 0; outline: 0} .clearfix::after { content:""; height: 0; display: block; clear: both; } div .container { width: 1300px; margin: auto; background: #fff; } header { width: 100%; height: 130px; border-top: 8px solid #a292b3; position: fixed; z-index: 2; } .logo { margin: 30px 0 20px 170px; } .menu { float: right; margin-right: 145px; } .menu li { display: inline-block; list-style: none; padding: 35px; }  


    • By Рома
      Доброго дня!
      Есть многоуровневое меню (картинка 1)
      Жму на кнопку Каталог - открывается блок с дополнительным содержимым. В этом содержимом есть подменю и под-под меню. Проблема тут такая часть содержимого из правого под-под меню не умещается на экране. Все потому, что блок с доп. содержимым относительно кнопки КАТАЛОГ открывается с выравниванием по левой своей части.
      Вот код в этом положении
      .cs-menu-container .dropdown, ul.type-category li .sub-cate { position: absolute; top: auto; left: 0; z-index: 1000; float: none; min-width: 230px; padding: 0; margin: 0; border: 1px solid #cccccc; border-top:2px solid #c04a62; background: #fff; Что я делаю: 
      меняю значение left: на -200px;
      В итоге получаю нужное мне расположение (картинка 2)
      Но тут же исправляя одно я получаю вторую проблему: блок содержимого кнопки ИНФОРМАЦИЯ уходит далеко влево от самой кнопки вызова (картинка 3)
       
      Какие мне элементы использовать в коде, чтобы выравнивание всех блоков меню (который появляется при нажатии на кнопку) происходило по центру самого блока относительно кнопки? Как правильно выровнять блок относительно кнопки?
       



    • By garmoni
      Нашла анимацию гамбургер меню из трех полосок в крестик. Не могу понять как к нему прикрепить появление самого меню при нажатии.
      <nav class="nav"> <div class="nav__btn"> <a id="nav-toggle" href="#"><span></span> </a> </div> <ul class="nav__list"> <li> <a href="#" class="nav__link">Episodes</a> </li> <li> <a href="#" class="nav__link">Characters</a> </li> <li> <a href="#" class="nav__link">Park</a> </li> <li> <a href="#" class="nav__link">Gallery</a> </li> <li> <a href="#" class="nav__link">actors</a> </li> </ul> </nav> $(document).ready(function(){ $('#nav-toggle').click(function(){ $(this).toggleClass('active'); }); .nav__list { display: none; } #nav-toggle {position: relative; display: inline-block; width:42px; height:25px;} #nav-toggle span { position: absolute; left: 0; top: 10px; } #nav-toggle span, #nav-toggle span:before, #nav-toggle span:after { position: absolute; display: block; content: ''; height: 5px; width: 42px; background: #000; border-radius: 2px; cursor: pointer; } #nav-toggle span:before { top: -10px; } #nav-toggle span:after { bottom: -10px; } /* Добавим анимацию всех свойств для блоков нашей иконки */ #nav-toggle span, #nav-toggle span:before, #nav-toggle span:after { transition: all 500ms ease-in-out; } /* Центральный блок делаем прозрачным */ #nav-toggle.active span { background-color: transparent; } /* Смещаем псевдо-элементы в центр иконки (на место основного блока) */ #nav-toggle.active span:before, #nav-toggle.active span:after { top: 0; } /* Наклоняем псевдо-элементы под углом 45 градусов, но в разные стороны */ #nav-toggle.active span:before { transform: rotate(45deg); } #nav-toggle.active span:after { transform: rotate(-45deg); }  
    • By d0ublezer0
      Собственно, вопрос в заголовке.
      Хочется добротное адаптивное меню, складывающееся в гамбургер. Нравится поведение http://mmenu.frebsite.nl/ с выплывающими уровнями в мобильной версии, но оно устроено так, что растянуто по всей высоте, как в приложении. А в десктопном варианте оно должно именно "выпадать". например, как на https://www.ulmart.ru/catalog/mobile_charger
      Поделитесь советами из опыта пожалуйста?
       
       
×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue. See more about our Guidelines and Privacy Policy