如果找不到图像,则javascript不显示图像占位符

时间:2011-08-05 21:39:15

标签: javascript

如果找不到图像,有没有办法不显示图像占位符?我已经通过自动进纸加载图像,对于某些项目图像是有的,但对于一些没有。所以,如果图像不存在,我想显示占位符。

谢谢,

ħ

3 个答案:

答案 0 :(得分:1)

我找到了答案here

这段代码效果很好!

function onImgErrorSmall(source)
{
source.src = "/images/no-image-100px.gif";
// disable onerror to prevent endless loop
source.onerror = "";
return true;
}

然后像这样称呼它:

<img src="/images/19013_small.jpg" alt="" onerror="onImgErrorSmall(this)" />

答案 1 :(得分:0)

试试这个:

   var tester=new Image()
   tester.onload=function() {createPlaceHolderForImage(); }
   tester.onerror=function() {handleError(); }
   tester.src="http://www.temp.com/image.jpg"
如果图像存在则调用

onload函数,否则调用handleError

答案 2 :(得分:0)

以下是使用jQuery的示例,这也可以在JavaScript中完成:

<script type="text/javascript">
$(document).ready(function(){
    $("img").each(function(){
        var imgObj = $(this);
        var img = new Image();
        img.onerror=function(){ imgObj.attr('src','placeholder.gif'); }
        img.src = imgObj.attr('src');
    });
});
</script>
<ul>
<li><img src="blah.gif" /></li>
<li><img src="blah.png" /></li>
<li><img src="http://www.google.com/intl/en_com/images/srpr/logo2w.png" /></li>
</ul>

此代码将遍历每个图像并检查它是否存在。如果它不存在则将其替换为'placeholder.gif'图像。