ECMAScript 2017 uyumlu tarayıcılar için çözüm
Not: Bu, Babel gibi bir transpiler kullanıyorsanız da işe yarayacaktır.
'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();
Ayrıca tüm görüntülerin yüklenmesini beklemiş olabilirsiniz.
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);
}
Veya Promise.all
paralel olarak yüklemek için kullanın .
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);
}
Promises hakkında daha fazla bilgi .
"Async" işlevleri hakkında daha fazla bilgi .
Yıkım ödevi hakkında daha fazla bilgi .
ECMAScript 2015 hakkında daha fazla bilgi .
ECMAScript 2017 hakkında daha fazla bilgi .
img
nesneye, örneğin üst kapsamdaki bir dizide başvuru tutun .