Maison > Questions et réponses > le corps du texte
P粉2760641782023-08-15 13:57:52
Une façon est d'écrire comme ceci :
useEffect(() => { let notesData = []; const fetchNote = async () => { const response = await fetch('https://notes-keeper-react-default-rtdb.firebaseio.com/notes.json'); const data = await response.json(); for (const key in data) { notesData.push({ id: key, title: data[key].title, note: data[key].note }); } setData(notesData); // 在这里数据已经准备好了 }; fetchNote(); }, []);
fetchNote
是一个异步函数,所以它需要一些时间来完成任务并获取数据。因此,你应该等待数据准备好,不幸的是,当你在调用 fetchNote()
后立即使用 setData(notesData)
Les données ne sont pas encore prêtes.
Alternativement vous pouvez renvoyer les données à l'intérieur de la fonction asynchrone et renvoyer automatiquement une autre promesse qui résout les données requises, puis vous pouvez mettre à jour vos données :
useEffect(() => { let notesData = []; const fetchNote = async () => { const response = await fetch('https://notes-keeper-react-default-rtdb.firebaseio.com/notes.json'); const data = await response.json(); for (const key in data) { notesData.push({ id: key, title: data[key].title, note: data[key].note }); } return notesData; // 返回一个解析为 'notesData' 的 promise }; fetchNote() .then((updatedData) => { setData(updatedData); }) }, []);