I have a script like this that performs an animation for a horizontal accordion. Whenever a different slide (li) on the accor开发者_Go百科dion is opened it is put inside the 'active' object.
<script type="text/javascript" >
$(document).ready(function(){
active = $('ul li:first-child');
$('ul li').click(
function(){
$(active).animate({width: '40px'}, { queue:false, duration:600 });
$('div').fadeOut(100).delay(400).fadeIn(100);
$(this).animate({width: '660px'}, { queue:false, duration:600});
active = this;
}
);
});
</script>
The animations all work great but the only problem is that when I click on the currently opened slide it runs this--
$('div').fadeOut(100).delay(400).fadeIn(100);)
How do I exclude the currently opened slide from running this? I've tried .not and :not but maybe I'm doing it incorrectly.
try putting a guard clause before you animate anything... something like
if (active == this) return;
as first line in the click handler function?
Shouldn't
if(this != active[0]) $('div').fadeOut(100).delay(400).fadeIn(100);
work?
jQuery has a little known way of dealing with this very problem. Use the .not() function. You can use that to remove elements from the jQuery object.
I would do something like this:
<script type="text/javascript" >
$(document).ready(function(){
active = $('ul li:first-child');
$('ul li').not('li.open').click(
function(){
$(this).addClass('open');
$(active).animate({width: '40px'}, { queue:false, duration:600 });
$('div').fadeOut(100).delay(400).fadeIn(100);
$(this).animate({width: '660px'}, { queue:false, duration:600});
$(active).click(function() { event.StopPropagation(); });
active = this;
}
);
});
</script>
The important lines are .not('li.open') and then "$(this).addClass('open')".
You'll need to add a way off removing the 'open' class from all li's once the menu closes, but not knowing your HTML I can't tell you how best to do that.
精彩评论