[D-5] 기본 기능 구현하기
2020. 1. 25. 00:26ㆍProject D (ToDoList)
반응형
src/
App.js
더보기
import React, { useState } from 'react';
import TodoInsert from './components/TodoInsert';
import TodoList from './components/TodoList';
import TodoTemplate from './components/TodoTemplate';
const App = () => {
const [todos, setTodos] = useState([
{
id: 1,
text: '리액트 기초',
checked: true,
},
{
id: 2,
text: '컴포넌트 스타일링',
checked: true,
},
{
id: 3,
text: '일정 관리 앱 제작',
checked: false,
},
]);
return (
<TodoTemplate>
<TodoInsert />
<TodoList todos={todos} />
</TodoTemplate>
);
};
export default App;
src/components
TodoList.js
더보기
import React from 'react';
import TodoListItem from './TodoListItem';
import './TodoList.scss';
const TodoList = ({ todos }) => {
return (
<div className="TodoList">
{todos.map(todo => (
<TodoListItem todo={todo} key={todo.id} />
))}
</div>
);
};
export default TodoList;
리액트 아이콘
https://react-icons.netlify.com/#/icons/md
src/
TodoListItem.js
더보기
import React from 'react';
import {
MdCheckBoxOutlineBlank,
MdCheckBox,
MdRemoveCircleOutline,
} from 'react-icons/md';
import cn from 'classnames';
import './TodoListItem.scss';
const TodoListItem = ({ todo }) => {
const { text, checked } = todo;
return (
<div className="TodoListItem">
<div className={cn('checkbox', { checked })}>
{checked ? <MdCheckBox /> : <MdCheckBoxOutlineBlank />}
<div className="text">{text}</div>
</div>
<div className="remove">
<MdRemoveCircleOutline />
</div>
</div>
);
};
export default TodoListItem;
src/components
TodoInsert.js
더보기
import React from 'react';
import { MdAdd } from 'react-icons/md';
import './TodoInsert.scss';
const TodoInsert = () => {
return (
<form className="TodoInsert">
<input placeholder="할 일을 입력하세요." />
<button type="submit">
<MdAdd />
</button>
</form>
);
};
export default TodoInsert;
반응형
'Project D (ToDoList)' 카테고리의 다른 글
[D-7] 항목 삭제기능 구현하기 (0) | 2020.01.25 |
---|---|
[D-6] 항목 추가기능 구현하기 (0) | 2020.01.25 |
[D-4] 컴포넌트 스타일링 (0) | 2020.01.24 |
[D-3] 컴포넌트 UI 구성 (0) | 2020.01.24 |
[D-2] 프로젝트 생성 및 필요한 라이브러리 설치 (0) | 2020.01.24 |