You can do with multiple backgrounds .
The background
property accepts multiple stacked layers as layers, layered over each other.
You can take advantage of this by defining the image that has the possibility of failing (not existing) as the first layer of background. If there are other images, you can put them in sequence but leave the last layer with the default image to be used if all the previous ones will fail.
In case the first is not found, the second will be used. If you have multiple images, the first one that does not crash will be searched in sequential order.
.logo {
width: 235px;
height: 90px;
background: url('imagemQueVaiFalhar.png'),
url('http://i.stack.imgur.com/pqk9d.png'); /* default */
}
<div class='logo'></div>
It is possible to have a base64 image, in case the second image has also been deleted, perhaps by accident. But there are a few factors to consider, especially in older browsers. Still, here is an example:
.logo {
width: 235px;
height: 90px;
background: url('imagemQueNuncaVaiExistir.jpg'),
url('imagemQueSubstituiAPrimeira.jpg'),
url('imagemColoqueiPorDefaultEOUsuarioApagou.png'),
url('');
}
<div class='logo'></div>