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); // 在這里數(shù)據(jù)已經(jīng)準(zhǔn)備好了 }; fetchNote(); }, []);
fetchNote
是一個(gè)異步函數(shù),所以它需要一些時(shí)間來完成任務(wù)并獲取數(shù)據(jù)。因此,你應(yīng)該等待數(shù)據(jù)準(zhǔn)備好,不幸的是,當(dāng)你在調(diào)用 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; // 返回一個(gè)解析為 'notesData' 的 promise }; fetchNote() .then((updatedData) => { setData(updatedData); }) }, []);