12

ファンシーボックスでページ全体をリクエストするのではなく、ページ上の特定の DIV ID をターゲットにするようにするにはどうすればよいですか? これは私のコードです

$(function() {

$(".style_image a").live('click', function(event) { 

    $(".style_image a").find("#show_style").fancybox();       

});
});

これは機能しませんか?

私はもともと次のことを試しました:

 $(function() {

    $(".style_image a").live('click', function(event) { 

        $(this.href + " #show_style").fancybox();       

    });
    });

これがどのように行われたのか、またはそれが可能かどうかさえわかりませんか?

ここにドキュメントがあります

4

2 に答える 2

24

fancybox で特定の div を開きたい場合は、次の簡単な手順を使用します。

まず、FancyBox をフックするためのリンクが必要です。

<a href="#myDivID" id="fancyBoxLink">Click me to show this awesome div</a>

アンカーの横にあるdiv idに注意してください。

次に、FancyBox 内に表示される div が必要です。

<!-- Wrap it inside a hidden div so it won't show on load -->
<div style="display:none">
    <div id="myDivID">
         <span>Hey this is what is shown inside fancybox.</span>
         <span>Apparently I can show all kinds of stuff here!</span>
         <img src="../images/unicorn.png" alt="" />
         <input type="text" value="Add some text here" />
    </div>
</div>

3 つ目は、すべてをまとめるための非常に簡単な JavaScript です。

<script type="text/javascript">
    $("a#fancyBoxLink").fancybox({
        'href'   : '#myDivID',
        'titleShow'  : false,
        'transitionIn'  : 'elastic',
        'transitionOut' : 'elastic'
    });
</script>
于 2010-09-29T06:48:54.453 に答える
7

このセレクターが必要です:

$("#show_style").fancybox();  

IDセレクター(IDは一意でなければならないため)は#IDGoesHere

あなたが求めているのは、ファンシーボックスにコンテンツをロードすることだと思い<div id="content"></div>ます.hrefが指すページからロードしたい場合は、次を使用してこれを行います.load():

$(".style_image a").on('click', function(event) { 
  $('#show_style').load(this.href + " #content").fancybox();       
});

.load()url selector宛先ページの一部のみをロードするオプションがあります。

于 2010-04-10T10:30:35.893 に答える