一種方法是這樣寫:
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
是一個非同步函數(shù),所以它需要一些時間來完成任務(wù)並取得資料。因此,你應(yīng)該等待資料準(zhǔn)備好,不幸的是,當(dāng)你在呼叫 fetchNote()
後立即使用 setData(notesData)
時,資料還沒準(zhǔn)備好。
或你可以在非同步函數(shù)內(nèi)部返回數(shù)據(jù),並自動返回另一個解析為所需數(shù)據(jù)的 promise,然後你可以更新你的數(shù)據(jù):
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); }) }, []);