Superagent 不断重复发送相同的图像

Superagent keeps sending same image repeatedly

我正在尝试能够上传多个文件并将它们发送到 Cloudinary 的 API。我正在遍历每张图片,附加它然后上传它。但是,我的代码循环遍历图像,然后再次上传第一张图像以获得文件数量:

let uploadRequest = superagent.post(url)

    for (let i=0; i<files.length; i++){
        uploadRequest.attach('file', files[i])
        console.log('file attached', files[i])

        Object.keys(params).forEach((key) => {
            uploadRequest.field(key, params[key])
        })
        console.log('params attached', files[i])

        uploadRequest.then((res) => {

            console.log('UPLOAD COMPLETE: '+JSON.stringify(res.body))
            const uploaded = res.body
            const imageUrl = res.body.secure_url
            let updatedArr = this.state.images.slice();
            updatedArr.push(imageUrl);
                this.setState({
                    images: updatedArr
                })
            })

        .catch((error) => {
            console.log(error)
            return
        })
    }

}

我怎样才能重写它来做我想做的事?困惑为什么这种情况一直发生

循环中间不能有异步代码。循环不等待请求完成。

将所有内容移至单独的函数,然后使用循环调用该函数。

var uploadFile = function(file){
    //do stuff
}

for(var i=0; i<files.length; i++){
    uploadFile(files[i]);
}