猿问

如何同步上传图片?

我尝试延迟显示图像,直到所有图像都上传(在浏览器中),但我的代码继续(不等待上传)。


我正在使用承诺和异步等待。这是我的代码:


async _renderPhotos(data){

    console.log("step6.1");

    const photoSetDiv = document.createElement("div");

    photoSetDiv.classList.add("photoSet");

    // photoSetDiv.classList.add("unvisible");

    photoSetDiv.id=`photoSet${this._step}`;

    const urlArray=data.map( image => image.url);


    await this._uploadAllImages(data, photoSetDiv);

    console.log("step6.3");

    this._container.appendChild(photoSetDiv);


}


 _uploadAllImages(array, container){

    var index=0;


    //upload each of the images is  separate promise

    function checkImage(item){new Promise ((resolve, reject) =>{


        //Creating <figure>, <img> and <div>.

        const figure = document.createElement("figure");

        figure.classList.add(item.site);

        const title = document.createElement("div");

        title.classList.add("titleImage");

        title.innerHTML =`#${item.site}`;

        figure.appendChild(title);

        const img = new Image();

        img.classList.add("image");


        img.onload=() => {

            console.log("step 6.2");

            const classCSS=figureClass(index);

            figure.classList.add(classCSS);

            figure.appendChild(img);

            container.appendChild(figure);

            index ++;

            resolve(item)}


        img.src=item.url;

        // Event on the image: after clicking on the image it is erlarged

        img.onclick= () => {

            modal.style.display = "block";

            modalImg.src=item.url;

        };

    })};


    return  Promise.all(array.map(checkImage));

}

我想等待上传图片。等效:在控制台中按以下顺序显示: step 6.1 step 6.2 (多次因为图片多) step 6.3


浮云间
浏览 117回答 1
1回答

UYOU

await和Promise.all/的陷阱之一race是,您可以在非承诺中使用它们,这只会评估价值本身。所以这:&nbsp;&nbsp;await&nbsp;undefined;&nbsp;&nbsp; &nbsp;&nbsp;await&nbsp;Promise.all([&nbsp;undefined,&nbsp;undefined&nbsp;]);将直接运行,而不会发出任何警告(好吧,不完全是,它会等待两个 microticks)。这就是你的情况。您没有return执行从 中创建的承诺checkImage,因此您基本上调用Promise.all了undefineds数组。
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答