破碎图像链接的图像占位符?

时间:2015-10-20 07:45:58

标签: php html css image placeholder

目前,用户可以将图像上传到我的网站,图像的位置存储在MySQL表中。

当我用SELECT函数调用图像时,它们通过CSS样式加载 background-image:url('image.jpg')

目前我使用了一个IF语句,它将占位符图像放在“Image_URL”列设置为NULL的任何行的位置。

if ($row["Image"] != "") {                  
                    echo "<td width='200' rowspan='3'><center><a href='/uploads/".$row["Image"]."' target='_blank'><div class='image-cropper'><div class='rounded' style='background-image:url(\"/uploads/".$row["Image"]."\")'>";
                } else {
                    echo "<td width='200' rowspan='3'><center><a><div class='image-cropper'><div class='rounded' style='background-image:url(\"/images/no-image.jpg\")'";
                }

然而,我的方法不适用于错误的链接(原始图像已删除,或者由于某种原因,链接错误。)它只显示空白,我可以看到原因,因为 $ row [“Image”]!= NULL ,那里有一个链接,它只是没有链接到图像。

如果在提供的链接中找不到图像,有没有办法加载我的占位符图片no-image.jpg?

我的DIV只是为了使我的图像循环和居中,所以我将它们发布在这里以防它有用,你可以帮我调整这些类来添加占位符功能。

.image-cropper {
    max-width: 150px;
    height: auto;
    position: relative;
    overflow: hidden;
}
.rounded {
    display: block;
    margin: 0 auto;
    height: 150px;
    width: 150px;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    -ms-border-radius: 50%;
    -o-border-radius: 50%;
    border-radius: 50%;
    background:center no-repeat;
    background-size:cover;
}

图像裁剪器和圆角DIV实际上来自此网站,所以感谢Hiral

2 个答案:

答案 0 :(得分:1)

我在使用file_exists之后设法使用glob让它工作。

但是,谢谢Stewartside让我走上了正确的道路,并构建了if陈述。

这是现在的代码:

$image = $row["Image"];
if ($row["Image"] != "") {  
    if (file_exists('uploads/'.$image)) {               
        echo "<td width='200' rowspan='3'><center><a href='/uploads/".$row["Image"]."' target='_blank'><div class='image-cropper'><div class='rounded' style='background-image:url(\"/uploads/".$row["Image"];
    } else {
        echo "<td width='200' rowspan='3'><center><a><div class='image-cropper'><div class='rounded' style='background-image:url(\"/images/no-image.jpg";
    }
    } else {
        echo "<td width='200' rowspan='3'><center><a><div class='image-cropper'><div class='rounded' style='background-image:url(\"/images/no-image.jpg";
}

我认为以下内容也有效:

    if (file_exists('uploads/'.$row["Image"])) {    

感谢大家的帮助! :)

答案 1 :(得分:0)

您可以使用glob()函数来确定文件是否存在。

这些方面的东西:

if ($row["Image"] != "") {
  var $file = glob("/uploads/".$row["Image"]); 
  if (count($file) > 0) {
    echo "<td width='200' rowspan='3'><center><a href='/uploads/".$row["Image"]."' target='_blank'><div class='image-cropper'><div class='rounded' style='background-image:url(\"/uploads/".$row["Image"]."\")'>";
  } else {
    echo "<td width='200' rowspan='3'><center><a><div class='image-cropper'><div class='rounded' style='background-image:url(\"/images/no-image.jpg\")'";
  }
} else {
  echo "<td width='200' rowspan='3'><center><a><div class='image-cropper'><div class='rounded' style='background-image:url(\"/images/no-image.jpg\")'";
}