我正在创建一个带弹出窗口的网站。弹出窗口最多可包含12个图像。我正在调用我的图片pizza1.jpg,pizza2.jpg,pizza3.jpg等等。
有没有任何方法可以使用纯JavaScript来显示图像,只有实际上有一个文件的名称我告诉它要查找?
This Question类似,但所有答案都很复杂,而且只是中度相关。
答案 0 :(得分:5)
您可以使用onError
事件从弹出窗口删除对象:
<img src="src" onError="removeElement(this);" />
检查它是否有效:
function removeElement(element) {
element.remove();
}
答案 1 :(得分:1)
您应该处理img
元素的onerror
事件。
答案 2 :(得分:1)
您可以创建Image instance并使用其onload事件来查看它是否已加载。如果是这样,只需将图像附加到任何元素。
演示
var imgurls = [
"https://placekitten.com/g/64/64",
"https://placekitten.com/g/32/32",
"https://placekitten.com/g/none/200",
"https://placekitten.com/g/100/100",
"https://placekitten.com/g/24/24"
];
imgurls.forEach(function(url){
let img = new Image();
img.onload = onImageLoad;
img.src = url;
});
function onImageLoad(){
document.body.appendChild(this);
}
&#13;
<div id="container">
</div>
&#13;