2

我想在downloadURL调用这个函数时返回,它是一个 firebase 上传函数。

import { storage } from "./base";
import firebase from "firebase";

function uploadFile(file, metadata) {
  return new Promise((resolve, reject) => {
    const task = storage.child(`/${file.name}`).put(file, metadata);

    task.on(
      firebase.storage.TaskEvent.STATE_CHANGED,
      function(snapshot) {
        var progress = (snapshot.bytesTransferred / snapshot.totalBytes) * 100;
        console.log(progress);
      },
      function(error) {
        switch (error.code) {
          case "storage/unauthorized":
            break;
          case "storage/canceled":
            break;
          case "storage/unknown":
            break;
          default:
            break;
        }
        reject(error);
      },
      function() {
        task.snapshot.ref.getDownloadURL().then(function(downloadURL) {
            resolve(downloadURL);
          console.log(downloadURL);
        });
      },
    );
  });
}

export { uploadFile };

我试过这个,它不返回downloadURL

4

2 回答 2

1

你可以简单地尝试如下:

  1. 在需要的地方导入文件。
  2. 然后使用相关参数调用该函数。
  3. 在 promise 中使用then方法来解决downloadUrl

    uploddFile(file, data).then(downloadUrl => console.log(downloadUrl) );

于 2019-03-05T06:51:03.410 回答
1

试试这个。

         import { storage } from "./base";
         import firebase from "firebase";

         function uploadFile(file, metadata) {
          return new Promise((resolve, reject) => {
          const task = storage.child(`/${file.name}`).put(file, metadata);

          task.on(
           firebase.storage.TaskEvent.STATE_CHANGED,
            function(snapshot) {
             var progress = (snapshot.bytesTransferred / snapshot.totalBytes) * 100;
        console.log(progress);
      },
      function(error) {
        switch (error.code) {
          case "storage/unauthorized":
            break;
          case "storage/canceled":
            break;
          case "storage/unknown":
            break;
          default:
            break;
        }
        reject(error);
      },
        task.snapshot.ref.getDownloadURL().then(function(downloadURL) {
            resolve(downloadURL);
          console.log(downloadURL);
        });
      ,
    );
  });
}

想法是在 getDownloadURL 成功后包含 resolve 方法。然后可以通过上述答案中提到的调用来检索它

     uploadFile(file, metaData)
     .then((download) => console.log(downloadURL)) ; // Or whatever you want to do wth downloadURL
于 2019-03-05T07:17:04.887 回答