2012-04-05 98 views
0

编辑:问题可以在这里看到:http://school.collegebrain.com/images/university-of-washington/。它只发生了1/15次,但这仍然是太频繁。fancybox图像有时会渲染外框

我有以下的Django模板:

<script type="text/javascript" src="{{ STATIC_URL }}js/ 
jquery.fancybox-1.3.4.pack.js"></script> 
<link rel="stylesheet" href="{{ STATIC_URL }}css/ 
jquery.fancybox-1.3.4.css" type="text/css" media="screen" /> 
{% include "submission-form.html" with section="photos" %} 
<div class="commentables"> 
     {% load thumbnail %} 
    {% for story in objects %} 
      <div class="image {% if forloop.counter|add:"-1"| 
divisibleby:picsinrow %}left{% else %}{% if forloop.counter| 
divisibleby:picsinrow %}right{% else %}middle{% endif %}{% endif %}"> 
       {% if story.image %} 
        {% thumbnail story.image size crop="center" as full_im %} 
           <a rel="gallery" href="{% url post slug=story.slug %}"> 
           <img class="preview" {% if story.title %} 
alt="{{ story.title }}" {% endif %} src="{{ full_im.url }}" full- 
image="{% if story.image_url %}{{ story.image_url }}{% else %} 
{{ story.image.url }}{% endif %}"> 
             </a> 
        {% endthumbnail %} 
       {% else %} 
         {% if story.image_url %} 
          {% thumbnail story.image_url size crop="center" as 
full_im %} 
           <a rel="gallery" href="{% url post slug=story.slug %}"> 
             <img class="preview" {% if story.title %} 
alt="{{ story.title }}" {% endif %} src="{{ full_im.url }}" full- 
image="{{ story.image_url }}"> 
               </a> 
          {% endthumbnail %} 
         {% endif %} 
       {% endif %} 
     </div> 
    {% endfor %} 
     {% if rowid != "last" %} 
     <br style="clear: both" /> 
     {% endif %} 
    {% if not no_more_button %} 
    <p style="text-align: right;" class="more-results"><a href="{% url 
images school_slug tag_slug %}">more...</a></p> 
    {% endif %} 
</div> 
<script> 
    $(document).ready(function(){ 
     function changeattr(e){ 
      var f = $(e.clone()); 
      $(f.children()[0]).attr('src', $(f.children() 
[0]).attr("full-image")); 
      $(f.children()[0]).attr('height', '500px'); 
      return f[0].outerHTML; 
     } 
     $('.image a').each(function(idx, elem) { 
      var e = $(elem); 
      e.fancybox({ 
       title: $(e.children()[0]).attr('alt'), 
      content: changeattr(e) 
      }); 
     }); 
    }); 
</script> 

,我偶尔会越来越怪异的显示错误在该框将 要么不呈现在所有东西(所以它会显示为只是薄薄的白色 基本上),或者它只会渲染大约30像素宽,并且 会在页面中间位置一半。在这两种情况下,如果我检查 元素,我可以看到完整图片的“阴影”,在正确的 大小,与正确的URL。

图像源似乎没有什么差异,我没有得到 错误,并且这在Chrome和Firefox中都有发生。 有没有人有任何想法?

编辑:上搞砸了一箱视图选择源给

<div id="fancybox-outer"><div class="fancybox-bg" id="fancybox-bg-n"></div><div class="fancybox-bg" id="fancybox-bg-ne"></div><div class="fancybox-bg" id="fancybox-bg-e"></div><div class="fancybox-bg" id="fancybox-bg-se"></div><div class="fancybox-bg" id="fancybox-bg-s"></div><div class="fancybox-bg" id="fancybox-bg-sw"></div><div class="fancybox-bg" id="fancybox-bg-w"></div><div class="fancybox-bg" id="fancybox-bg-nw"></div><div style="border-width: 10px; width: 165px; height: auto; opacity: 1;" id="fancybox-content"><div style="width: auto; height: auto; overflow: auto; position: relative;"><a rel="gallery" href="/post/shit-is-about-to-get-real/"> 
          <img class="preview" alt="shit IS about to get real" src="http://i.imgur.com/Le8Kv.jpg" full-image="http://i.imgur.com/Le8Kv.jpg" height="500px"> 
         </a></div></div><a style="display: inline;" id="fancybox-close"></a><a style="display: inline;" href="javascript:;" id="fancybox-left"><span class="fancy-ico" id="fancybox-left-ico"></span></a><a style="display: inline;" href="javascript:;" id="fancybox-right"><span class="fancy-ico" id="fancybox-right-ico"></span></a></div> 
+0

而不是所有这些代码。在您的网页上查看源代码并发布。 – 2012-04-05 23:34:35

+0

这个问题和这个问题之间的关系是什么http://stackoverflow.com/q/10035575/1055987? – JFK 2012-04-08 05:02:51

+1

您发布的内容是“我如何在弹出框中显示正确的内容?”这一个是“现在我弹出了正确的东西,我如何使弹出始终正确加载?” – Colleen 2012-04-09 16:13:35

回答

0

我与任何有关图片和javascript问题的第一个建议就是务必JavaScript知道图像的大小。设置尺寸(宽度和高度),看看你的问题是否得到解决。

+0

我对设置特定尺寸的担忧是我不希望较小的图像被拉伸。 – Colleen 2012-04-09 19:04:11

+0

对不起,并不意味着你应该拉伸它,我只是想知道是否将图像尺寸设置为它们应该(加载时)会修复问题。如果这可以修复渲染问题,那么我们可以讨论可能需要采取哪些CSS调整来修复布局。 – mikevoermans 2012-04-09 19:51:30

+0

好的。我应该在哪里设置图像大小? (例如,通过js,作为图像标签本身的属性,作为css属性..?) – Colleen 2012-04-09 21:27:56