반응형
App.js 에 있는 expenses 배열 변수에 값을 추가해야 한다.
그리고 우리가 이미 알다시피 변수만 바꾸는 것은 화면 상의 데이터를 변경하지 않기 때문에
useState 를 사용해야 한다.
setState와 관련된 에러에 멈췄다
prev 이전 함수들과 섞는 과정에서 문제가 있는데 왜 이렇게 결과가 나왔는지 몰라서 헤매고 있다..
import { useState } from 'react';
import './App.css';
import Expenses from './components/Expenses/Expenses';
import NewExpense from './components/NewExpense/NewExpense';
const DUMMY_EXPENSES = [
{
id: 'e1',
title: 'Toilet Paper',
amount: 94.12,
date: new Date(2022, 7, 14),
},
{ id: 'e2', title: 'New TV', amount: 799.49, date: new Date(2023, 2, 12) },
{
id: 'e3',
title: 'Car Insurance',
amount: 294.67,
date: new Date(2023, 2, 28),
},
{
id: 'e4',
title: 'New Desk (Wooden)',
amount: 450,
date: new Date(2023, 5, 12),
},
];
const App = () => {
const [expenses, setExpense] = useState([]);
const addExpenseHandler = (expense) => {
// setExpense([expense]);
setExpense((prev) => {
return [expense, ...prev];
})
}
return (
<div className="App">
<NewExpense onAddExpense={addExpenseHandler} />
<Expenses items={expenses} />
</div>
);
}
export default App;
반응형
'온라인 강의 > React 완벽 가이드 [Udemy]' 카테고리의 다른 글
72. 연습하기 : Lists 다루기 (문제) (0) | 2023.06.04 |
---|---|
71. "keys" 이해하기 (0) | 2023.06.04 |
69. 데이터의 렌더링 목록 map() 사용 (0) | 2023.06.03 |
68. 모듈 소개 (0) | 2023.06.03 |
67. 모듈 리소스 (0) | 2023.06.03 |