我正在这个网站上工作,我希望当用户单击导航项时,div 会向右滑出并显示该部分的内容,并且当用户单击下一个导航项时,当前 div 会向后滑动进入左侧,下一个 div 将滑出到右侧。我在这里有这种工作:http: //fire4hirecatering.com/workingsite/
但是,如果您在单击每个导航项然后返回到页面后注意到它会在动画发生之前显示该 div 的内容。
我是 JQuery 的新手,所以我确定这不是完美的,但它是:
function navAbout() {
if($('#main_content').hasClass("redLeft")) {
//Current Div Content Slideout
$('.selected').animate({
width: '0px'
}, 1200, 'swing').hide(1200);
$('#aboutSlide').delay(1200).show().animate({
width: '550px'
}, 1200, 'swing' );
$('#aboutContent').delay(2400).fadeIn(600);
$("#aboutSlide").addClass("selected").not("#aboutSlide").removeClass("selected");
/*Below three lines were the only way to get the class "selected" removed, the code above wasn't working*/
$('#menuSlide').removeClass("selected");
$('#mediaSlide').removeClass("selected");
$('#contactSlide').removeClass("selected");
$('html').css("background-image", "url(img/bg_about.jpg)")
}
else {
//animate the redBG to the left when user clicks nav
$('#main_contentBG').animate({
left: '40px'
}, 1200, 'swing' );
$('#main_content').addClass('redLeft');
//About Div Content Slideout
$('#aboutSlide').delay(1200).show().animate({
width: '550px'
}, 1200, 'swing' );
$('#aboutSlide').addClass('selected');
$('#aboutContent').delay(2100).fadeIn(600);
//change background image
$('html').css("background-image", "url(img/bg_about.jpg)")
}
}
您可以在上面的链接中查看整个站点的源代码。JQuery 在 scripts.js 文件中。