2017-02-13 4 views
0
for (var i = 0; i < e.target.files.length; i++) { 
    var storageRef = firebase.storage().ref('user_files/' + e.target.files[i].name).put(e.target.files[i]); 
    storageRef.on('state_changed', null, null, function (snapshot) { 
     var downloadURL = storageRef.snapshot.downloadURL; 

     //i need all the files URL 
     //but always get the last file URL 
    }); 
} 

ответ

0

Когда вы звоните put(), возвращается UploadTask. В дополнение к методу on(), который вы используете, который также реализует then(). Это означает, что вы можете использовать его как обещание и таким образом использовать Promise.all:

for (var i = 0; i < e.target.files.length; i++) { 
    var promises = firebase.storage().ref('user_files/' + e.target.files[i].name).put(e.target.files[i]); 
    Promise.all(promises).then(function(results) { 
     var downloadURLs = results.map(function(taskSnapshot) { 
      return taskSnapshot.downloadURL 
     }); 
    }) 
} 

чуть более современную версию кода выше:

var files = firebase.storage().ref('user_files'); 

var promises = e.target.files.map((f) => files.child(f.name).put(f)); 

Promise.all(promises).then((results) => { 
    var downloadURLs = results.map((taskSnapshot) => taskSnapshot.downloadURL); 
}) 
Смежные вопросы