P粉2760641782023-08-15 13:57:52
一種方法是這樣寫:
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)
時,資料還沒準備好。
或你可以在非同步函數內部返回數據,並自動返回另一個解析為所需數據的 promise,然後你可以更新你的數據:
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); }) }, []);