Solusi untuk browser yang sesuai dengan ECMAScript 2017
Catatan: ini juga akan berfungsi jika Anda menggunakan transpiler seperti Babel.
'use strict';
function imageLoaded(src, alt = '') {
return new Promise(function(resolve) {
const image = document.createElement('img');
image.setAttribute('alt', alt);
image.setAttribute('src', src);
image.addEventListener('load', function() {
resolve(image);
});
});
}
async function runExample() {
console.log("Fetching my cat's image...");
const myCat = await imageLoaded('https://placekitten.com/500');
console.log("My cat's image is ready! Now is the time to load my dog's image...");
const myDog = await imageLoaded('https://placedog.net/500');
console.log('Whoa! This is now the time to enable my galery.');
document.body.appendChild(myCat);
document.body.appendChild(myDog);
}
runExample();
Anda juga bisa menunggu semua gambar dimuat.
async function runExample() {
const [myCat, myDog] = [
await imageLoaded('https://placekitten.com/500'),
await imageLoaded('https://placedog.net/500')
];
document.body.appendChild(myCat);
document.body.appendChild(myDog);
}
Atau gunakan Promise.alluntuk memuatnya secara paralel.
async function runExample() {
const [myCat, myDog] = await Promise.all([
imageLoaded('https://placekitten.com/500'),
imageLoaded('https://placedog.net/500')
]);
document.body.appendChild(myCat);
document.body.appendChild(myDog);
}
Lebih lanjut tentang Janji .
Lebih lanjut tentang fungsi "Async" .
Lebih lanjut tentang penugasan penghancuran .
Lebih lanjut tentang ECMAScript 2015 .
Lebih lanjut tentang ECMAScript 2017 .
imgobjek, misalnya dalam array dalam lingkup induk.