обещание использовать все функции getDownloadURL () в firebase - PullRequest
0 голосов
/ 07 января 2020

Я пытаюсь получить URL-адрес загружаемого изображения в хранилище Firebase.

Чего я хотел добиться с помощью этого кода, так это загружать два изображения одно за другим и вставлять URL-адрес изображения в массив.

Однако мой код работает неправильно как асинхронный. В результате после Promise.all () предполагается возвращение массива с URL. Я буду признателен, если кто-нибудь поможет мне решить эту проблему.

const handleUpload = () => {
    Promise.all([uploadImage(window1Image), uploadImage(window2Image)])
      .then((result) => {
        console.log(result);
      })
      .catch((err) => {
        console.log(err);
      });
  };

const uploadImage = (image) => {
    const uuid = Date.now() + uuidv4();
    const imageToServer = storage.ref(`images/${uuid}`).put(image);
    imageToServer.on(
      'state_changed',
      (snapshot) => {
        const progress = Math.round((snapshot.bytesTransferred / snapshot.totalBytes) * 100);
      },
      (error) => {
        console.log(error);
      },
      () => {
        storage
          .ref('images')
          .child(uuid)
          .getDownloadURL()
          .then((data) => data);
      },
    );
  };

1 Ответ

1 голос
/ 07 января 2020

Вы должны использовать then() метод UploadTask, который "ведет себя как Обещание и разрешается с данными моментального снимка после завершения загрузки ".

Должно работать следующее (не проверено):

  const handleUpload = () => {
    Promise.all([uploadImage(window1Image), uploadImage(window2Image)])
      .then(result => {
        console.log(result);
      })
      .catch(err => {
        console.log(err);
      });
  };

  const uploadImage = image => {
    const uuid = Date.now() + uuidv4();
    const imageToServer = storage.ref(`images/${uuid}`).put(image);
    return imageToServer.then(uploadTaskSnapshot => {
      return uploadTaskSnapshot.ref.getDownloadURL();
    });
  };
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...