我使用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网站,但没有关于动态加载内容的文档。帮助将不胜感激。
答案 0 :(得分:6)
您需要使用Shadowbox.clearCache();
和Shadowbox.setup();
重新初始化它
这里有更好的解释:shadowbox stops working after jquery function call