recherche

Maison  >  Questions et réponses  >  le corps du texte

Vous ne pouvez pas utiliser les résultats d'une fonction dans d'autres fonctions

J'ai deux fonctions

  1. convertToBase64(file) est utilisé pour convertir des fichiers
  2. addData(values) est utilisé pour envoyer des fichiers convertis. Mais le résultat de la deuxième fonction est toujours indéfini. Comment résoudre ce problème?
async function convertToBase64(file) {
  const fileReader = new FileReader();
  fileReader.onload = () => {
    const srcData = fileReader.result;
    console.log('scrData: ', srcData);     // result is correct
    return srcData;
  };
  fileReader.readAsDataURL(file);
}

async function addData(values) {
  const converted = await convertToBase64(values.file);
  console.log(converted);       // result undefined
  await addDoc(collection(db, 'list'), {
    image: converted,
  });
}

J'ai essayé les fonctions try...catch, async-wait, mais je n'ai quand même pas trouvé de solution

P粉087951442P粉087951442232 Il y a quelques jours551

répondre à tous(1)je répondrai

  • P粉436052364

    P粉4360523642024-04-02 11:48:48

    convertToBase64() 函数不会显式返回值,因此您提供的代码始终返回 undefined 。您可以更改该函数,使其返回一个Promise,一旦FileReader 已成功读取 base64 中的文件,并处理任何 rejections ou erreurs se sont produites :

    const imgFileInput = document.getElementById("img");
    imgFileInput.addEventListener("change", addData);
    
    function convertToBase64(file) {
      return new Promise((resolve) => {
        const fileReader = new FileReader();
        fileReader.onload = () => {
          const srcData = fileReader.result;
          resolve(srcData);
        };
        fileReader.onerror = (error) => {
          reject(error);
        };
        fileReader.readAsDataURL(file);
      });
    }
    
    async function addData() {
      try {
        const imgFile = imgFileInput.files[0];
        const converted = await convertToBase64(imgFile);
        console.log(converted);
      } catch (error) {
        console.error("Error while converting to Base64:", error);
      }
    }

    répondre
    0
  • Annulerrépondre