如何将多个文件上传到Firebase?

isu*_*uru 11 javascript firebase firebase-storage

有没有办法将多个文件上传到Firebase存储.它可以在单次尝试中上传单个文件,如下所示.

fileButton.addEventListener('change', function(e){ 
//Get file
var file = e.target.files[0];

//Create storage reference
var storageRef = firebase.storage().ref(DirectryPath+"/"+file.name);

//Upload file
var task = storageRef.put(file);

//Update progress bar
  task.on('state_changed',
    function progress(snapshot){

        var percentage = snapshot.bytesTransferred / snapshot.totalBytes * 100;
        uploader.value = percentage;
    },
    function error(err){

    },
    function complete(){
        var downloadURL = task.snapshot.downloadURL;

    }
  );

});
Run Code Online (Sandbox Code Playgroud)

如何将多个文件上传到Firebase存储.

isu*_*uru 16

我找到了上述问题的解决方案,我想把它放在这里因为它对任何人都有用.

//Listen for file selection
fileButton.addEventListener('change', function(e){ 
    //Get files
    for (var i = 0; i < e.target.files.length; i++) {
        var imageFile = e.target.files[i];

        uploadImageAsPromise(imageFile);
    }
});

//Handle waiting to upload each file using promise
function uploadImageAsPromise (imageFile) {
    return new Promise(function (resolve, reject) {
        var storageRef = firebase.storage().ref(fullDirectory+"/"+imageFile.name);

        //Upload file
        var task = storageRef.put(imageFile);

        //Update progress bar
        task.on('state_changed',
            function progress(snapshot){
                var percentage = snapshot.bytesTransferred / snapshot.totalBytes * 100;
                uploader.value = percentage;
            },
            function error(err){

            },
            function complete(){
                var downloadURL = task.snapshot.downloadURL;
            }
        );
    });
}
Run Code Online (Sandbox Code Playgroud)

  • 非常感谢!我花了一整天的时间试图了解 File 对象的整个过程,您的回答很有帮助。我唯一能想到的在这里添加的是整体上传进度,在这里实现起来并不容易。 (3认同)
  • 如果您像您一样放置多个并发上传任务,它们将依次上传 (2认同)

use*_*289 10

Firebase存储使用Promise,因此您可以使用Promises来实现它.

以下是涉及此主题的firebase博客文章: 保持我们的承诺(和回调)


给Promise.all()一个"承诺数组"

Promise.all(
  // Array of "Promises"
  myItems.map(item => putStorageItem(item))
)
.then((url) => {
  console.log(`All success`)
})
.catch((error) => {
  console.log(`Some failed: `, error.message)
});
Run Code Online (Sandbox Code Playgroud)

上传每个文件并返回Promise

putStorageItem(item) {
  // the return value will be a Promise
  return firebase.storage().ref("YourPath").put("YourFile")
  .then((snapshot) => {
    console.log('One success:', item)
  }).catch((error) => {
    console.log('One failed:', item, error.message)
  });
}
Run Code Online (Sandbox Code Playgroud)

YourPath并且YourFile可以用myItems数组(因此item对象)携带.

为了便于阅读,我在这里省略了它们,但是你得到了这个概念.

  • 您能否将其更新到当前的 Firebase 文档,或者至少分享如何获取当前正在运行的任务的进度,以便相应地更新 UI (2认同)

Mik*_*ald 8

我相信有一个更简单的解决方案:

// set it up
firebase.storage().ref().constructor.prototype.putFiles = function(files) { 
  var ref = this;
  return Promise.all(files.map(function(file) {
    return ref.child(file.name).put(file);
  }));
}

// use it!
firebase.storage().ref().putFiles(files).then(function(metadatas) {
  // Get an array of file metadata
}).catch(function(error) {
  // If any task fails, handle this
});
Run Code Online (Sandbox Code Playgroud)