Я создаю панель навигации и пытаюсь добавить этот эффект: когда вы наводите курсор на элемент главного меню, каждый элемент подменю под ним появляется с небольшой задержкой. Как один за другим.
Я немного сделал это, но это очень глючит. Иногда задержки занимают слишком много времени, иногда второй подпункт появляется раньше первого! И что самое ужасное, когда вы убираете мышь с основного пункта, список под ним исчезает! В общем не очень гладко. Вот код, который у меня есть сейчас.
HTML
<div id="navbar">
<ul id="main-menu">
<li><a href="#">Home</a></li>
<li><a href="#">About Us</a></li>
<li><a href="#">Members</a>
<ul>
<li><a href="#">Sub item 1</a></li>
<li><a href="#">Sub item 2</a></li>
</ul>
</li>
<li><a href="#">Events</a>
<ul>
<li><a href="#">Sub item 3</a></li>
<li><a href="#">Sub item 4</a></li>
</ul>
</li>
<li><a href="#">Publications</a>
<ul>
<li><a href="#">Sub item 5</a></li>
<li><a href="#">Sub item 6</a></li>
</ul>
</li>
<li><a href="#">Contact Us</a></li>
</ul>
</div>
CSS
#navbar { width:550px; height:30px; position:relative; float:right; right:-7px; top:30px; }
#main-menu { width:100%; float:right; list-style:none; }
#main-menu li { float:left; }
#main-menu li a { display:block; text-decoration:none; color:#000; background-color:#FC0; padding:8px; margin-right:10px; }
#main-menu li ul { display:none; z-index:999; }
#main-menu li:hover ul { display:block; position:absolute; }
#main-menu li li { display:block; float:none; }
JQuery
$(document).ready(function(e) {
$('#main-menu li a').hover(function()
{
$(this).animate({
backgroundColor : '#C60'
},200);
$('#main-menu ul li').each(function(e) {
$(this).delay(e * 200).hide().fadeIn(200);
});
}, function(){
$(this).animate({
backgroundColor : '#FC0'
},200);
});
});
См. эту скрипку здесь.
Как я могу сделать его гладким, функциональным?
setTimeout
иcleartimeout
вместоdelay
. Таким образом, вы можете лучше контролировать тайм-ауты.delay
использует то же самое, но у вас нет указателя тайм-аута для очистки тайм-аутов после прекращения зависания и т. д. - person Liam   schedule 02.11.2012