上部に画像、下部にメニューがあるページを作成しています。ユーザーが3つのメニューボタンの1つをクリックすると、画像のslideUpとページが下にスクロールしてメニューがページの上部に表示され、右側の.contentdivがフェードインします。slideUpはユーザーが初めて発生する場合にのみ発生します。ボタンをクリックします。
jQueryでこれを行うための絶対的な最善の方法は何ですか?(プラグインなし)
同じボタンを2回クリックした場合に、すでに表示されているページでフェードインするのを防ぐ方法も知っておく必要がありますか?
私はhrefの代わりにrelを使用しています。これは、hrefがfalseを返しても、ページをジャンプさせたためです。
これは私がこれまでに持っているものです:
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3/jquery.min.js"></script>
<script type="text/javascript">
$(function(){
imgVisible = true;
$('#mainmenu a').click(function(){
var $activeTab = $(this).attr('rel');
if(!imgVisible){
$('html:not(:animated),body:not(:animated)').animate({scrollTop:$('#mainmenu').offset().top-20},500);
$('.content').hide();
$($activeTab).fadeIn();
} else{
$('#imgholder').slideUp(500,function(){
imgVisible = false;
$('#mainmenu a[rel="'+$activeTab+'"]').click();
});
}
return false;
});
});
</script>
<div id="imgholder"><img src="image.jpg" /></div>
<div id="mainmenu">
<ul>
<li><a rel="#tab1"></a></li>
<li><a rel="#tab2"></a></li>
<li><a rel="#tab3"></a></li>
</ul>
</div>
<div id="container">
<div class="content" id="tab1">
content
</div>
<div class="content" id="tab2">
content
</div>
<div class="content" id="tab3">
content
</div>
</div>