Новые уроки
Получай новые уроки по RSS

Подписка на рассылку


Голосование
Чего выкладывать больше?
Программ
Уроков
Скриптов
Шаблонов
Макетов
CMS
Видеоуроков
Облако тегов

Jquery → Еще один вариант выпадающего меню

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

Наше меню будет выглядять вот так:
Еще один вариант выпадающего меню


Начнем.

Сначало напишем структуру меню:
<ul class="topnav">
    <li><a href="#">Home</a></li>
    <li>
        <a href="#">Tutorials</a>
        <ul class="subnav">
            <li><a href="#">Sub Nav Link</a></li>
            <li><a href="#">Sub Nav Link</a></li>
        </ul>
    </li>
    <li>
        <a href="#">Resources</a>
        <ul class="subnav">
            <li><a href="#">Sub Nav Link</a></li>
            <li><a href="#">Sub Nav Link</a></li>
        </ul>
    </li>
    <li><a href="#">About Us</a></li>
    <li><a href="#">Advertise</a></li>
    <li><a href="#">Submit</a></li>
    <li><a href="#">Contact Us</a></li>
</ul>


Придаем стиля нашему меню
ul.topnav {
    list-style: none;
    padding: 0 20px;
    margin: 0;
    float: left;
    width: 920px;
    background: #222;
    font-size: 1.2em;
    background: url(topnav_bg.gif) repeat-x;
}
ul.topnav li {
    float: left;
    margin: 0;
    padding: 0 15px 0 0;
    position: relative; /*--Declare X and Y axis base for sub navigation--*/
}
ul.topnav li a{
    padding: 10px 5px;
    color: #fff;
    display: block;
    text-decoration: none;
    float: left;
}
ul.topnav li a:hover{
    background: url(topnav_hover.gif) no-repeat center top;
}
ul.topnav li span { /*--Drop down trigger styles--*/
    width: 17px;
    height: 35px;
    float: left;
    background: url(subnav_btn.gif) no-repeat center top;
}
ul.topnav li span.subhover {background-position: center bottom; cursor: pointer;} /*--Hover effect for trigger--*/
ul.topnav li ul.subnav {
    list-style: none;
    position: absolute; /*--Important - Keeps subnav from affecting main navigation flow--*/
    left: 0; top: 35px;
    background: #333;
    margin: 0; padding: 0;
    display: none;
    float: left;
    width: 170px;
    border: 1px solid #111;
}
ul.topnav li ul.subnav li{
    margin: 0; padding: 0;
    border-top: 1px solid #252525; /*--Create bevel effect--*/
    border-bottom: 1px solid #444; /*--Create bevel effect--*/
    clear: both;
    width: 170px;
}
html ul.topnav li ul.subnav li a {
    float: left;
    width: 145px;
    background: #333 url(dropdown_linkbg.gif) no-repeat 10px center;
    padding-left: 20px;
}
html ul.topnav li ul.subnav li a:hover { /*--Hover effect for subnav links--*/
    background: #222 url(dropdown_linkbg.gif) no-repeat 10px center;
}


Сам скрипт выполняющий выпадение
<script type="text/javascript">
$(document).ready(function(){

    $("ul.subnav").parent().append("<span></span>");

    $("ul.topnav li span").click(function() {

        
        $(this).parent().find("ul.subnav").slideDown('fast').show();

        $(this).parent().hover(function() {
        }, function(){
            $(this).parent().find("ul.subnav").slideUp('slow');
        });

      
        }).hover(function() {
            $(this).addClass("subhover");
       }, function(){    
           $(this).removeClass("subhover");
    });
});
</script>


Меню сделано. Дальше лиш ограничение ваша фантазия.

Скачать: examples.rar [128,62 Kb] (cкачиваний: 157)
Опубликовал dimas_ua, 7-09-2010, 00:00 Комментариев: 2
 (голосов: 2)
Пишет devil, 7 сентября 2010 02:51
  • Сообщений: 0
  • Новостей: 0
По сути, всё верно и очень даже круто, только бы яву я спрятал в отдельный файл...
Пишет www.vipmaxcd.ru, 19 апреля 2011 05:07
  • Сообщений: 0
  • Новостей: 0
да яву не помешает спрятать, я то большой код получается