const list = [
"./img.png",//本地存在可加载成功
"//be-fe.github.io/static/images/iSlider-card/10.jpg",//加载图片失败
"./load.gif",//本地存在可加载成功
"//be-fe.github.io/static/images/iSlider-card/12.jpg",//加载图片失败
null,//无图片
"//be-fe.github.io/static/images/iSlider-card/17.jpg",//加载图片失败
];
const placeholder = '默认占位图';
const loadError = '加载失败图';
const gen = () => {
let endSrc = placeholder;
let html = '';
list.forEach((ele) => {
if(ele){
const image = new Image();
image.src = ele;
image.onload = () => {
endSrc = ele;
};
image.onerror = () => {
endSrc = loadError;
};
}
html += `<p>${endSrc}</p>`;
});
// 我期望取得html 、onload 和onerror后的值[load和error事件是异步的 所以目前获取不到]
return html;
}
$("body").append(gen())
