ファンシーボックスをカスタマイズして、ページに表示されている4つの画像のいずれかをクリックすると、これがファンシーボックスウィンドウにロードされるようにしようとしています.
これを行うには、jquery .attr 関数を使用して、画像 src を (変数として) メインの画像ホルダーに渡します。
私の現在のjqueryコードは次のとおりです。
jQuery(document).ready(function($) {
$("a.group").click(function() {
var image = $(this).attr("name");
$("#largeId").attr({ src: image});
$("a.group").fancybox({
'frameWidth':966,
'frameHeight': 547,
'hideOnContentClick': false,
'overlayOpacity': 0.85,
'callbackOnShow': function() {
$("#container ul#thumbnails li a").click(function(){
var largePath = $(this).attr("title");
$("#largeId").fadeOut("fast").hide();
$("#largeId").attr({ src: largePath });
$("#largeId").fadeIn("slow");return false;
});
$("#container ul#thumbnails li a").click(function(){
$('.active').removeClass('active');
$(this).addClass("active");
});
}
});
});
});
メイン ページの画像の HTML は次のとおりです。
<ul id="images">
<li><a id="one_image" class="group" href="#hidden" title="images/1_large.jpg"><img src="Images/1.jpg" alt="MOMA NY #1" title="MOMA NY #1" /></a></li>
<li><a class="group" href="#hidden" title="images/2_large.jpg"><img src="Images/2.jpg" alt="MOMA NY #2" title="MOMA NY #2" /></a></li>
<li><a class="group" href="#hidden" title="images/3_large.jpg"><img src="Images/3.jpg" alt="MOMA NY #3" title="MOMA NY #3" /></a></li>
<li><a class="group" href="#hidden" title="images/4_large.jpg"><img src="Images/4.jpg" alt="MOMA NY #4" title="MOMA NY #4" /></a></li>
</ul>
Fancybox ウィンドウの場合:
<div id="main_image">
<img id="largeId" src="" alt="" title="" />
</div>
- - - -編集 - - - - -
ご存知のように、これは、最初にクリック関数を取り除くとほとんど機能し、fancybox 呼び出し内の関数はすべて正常に動作します。