将Shadowbox.js应用于动态生成的内容

时间:2012-07-10 08:01:08

标签: javascript jquery

我使用shadowbox.js进行图库展示。

为此我们必须生成像这样的HTML

<a href="images/Ganesha3602.jpg" rel="shadowbox[my]"><img src="images/thumb.jpg"   alt="First" title="First image" /></a>
<a href="images/original.jpg" rel="shadow[my]"><img src="images/thumb.jpg" alt="Second" title="Second image" /></a>
<a href="images/original.jpg" rel="shadowbox[my]"><img src="images/thumb.jpg" alt="First" title="First image" /></a>

然后对身体负荷应用Shadowbox.init()。当上面的html是静态的时,它的工作就像一个魅力。但是当我使用$.ajax动态生成它并在成功时调用Shadowbox.init(); shadowbox不起作用。我也尝试在完成时调用Shadowbox.init()

我的代码是这样的:

$(document).on('click','#load_posts_comments',function(){

    $.ajax({
        url:"post_comment_json.php",
        type: "POST",
        dataType: "json",
        data:{user_id:"123"},
        success: function(data){
            load_posts_comments(data);
        },
        complete: function(){
            Shadowbox.init();
        }
    });
});

我哪里错了?我查看了shadowbox网站,但没有关于动态加载内容的文档。帮助将不胜感激。

1 个答案:

答案 0 :(得分:6)

您需要使用Shadowbox.clearCache();Shadowbox.setup();重新初始化它 这里有更好的解释:shadowbox stops working after jquery function call