{"id":29568890,"url":"https://github.com/fivethreeeo/react-practice-todolist","last_synced_at":"2025-12-31T14:14:03.779Z","repository":{"id":132942512,"uuid":"574298924","full_name":"fivethreeeo/react-practice-todolist","owner":"fivethreeeo","description":null,"archived":false,"fork":false,"pushed_at":"2022-12-21T15:04:38.000Z","size":39831,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2023-08-04T19:25:34.652Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/fivethreeeo.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null}},"created_at":"2022-12-05T01:52:10.000Z","updated_at":"2023-08-04T19:25:40.877Z","dependencies_parsed_at":null,"dependency_job_id":"ccd379c1-385e-465e-a7a6-e9d4cda302fa","html_url":"https://github.com/fivethreeeo/react-practice-todolist","commit_stats":null,"previous_names":["fivethreeeo/react-practice-todolist"],"tags_count":null,"template":null,"template_full_name":null,"purl":"pkg:github/fivethreeeo/react-practice-todolist","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/fivethreeeo%2Freact-practice-todolist","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/fivethreeeo%2Freact-practice-todolist/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/fivethreeeo%2Freact-practice-todolist/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/fivethreeeo%2Freact-practice-todolist/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/fivethreeeo","download_url":"https://codeload.github.com/fivethreeeo/react-practice-todolist/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/fivethreeeo%2Freact-practice-todolist/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":265866479,"owners_count":23840970,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2025-07-19T01:07:40.722Z","updated_at":"2025-12-31T14:14:03.733Z","avatar_url":"https://github.com/fivethreeeo.png","language":"JavaScript","readme":"# 리액트 미니 투두리스트 만들기\n\n## 데모\n\n\u003cimg width=\"300\" src=\"https://user-images.githubusercontent.com/41741221/205535871-c405136c-2b3d-4485-bbd1-fbe16b5605e0.gif\"\u003e\n\n\u003cbr\u003e\n\n## 프로젝트 실행 방법\n\n```\n  yarn start\n```\n\n\u003cbr\u003e\n\n## 기능 구현\n\n- [x] 할 일 추가\n- [x] 할 일 삭제\n- [x] 할 일의 진행 증, 완료 표시\n- [x] 로컬스토리지로 할 일 기억하기\n\n\u003cbr\u003e\n\n## 주요 작업 내용\n\n- 스타일링은 postcss(모듈객체를 활용)\n  - 이전에는 주로 BEM방식으로 작성했는데, 모듈을 활용하니 className 짓기나 전체적인 class 구조를 덜 고민할 수 있어서 편했다.\n\n\u003cbr\u003e\n\n- 로컬스토리지 사용\n  - `useEffect`를 활용해 `items` 상태가 변경될 때마다 로컬스토리지에 추가하도록 했다.\n  - 매번 로컬스토리지에 추가하는게 아니라, 언마운트될 때만 추가하는 것이 더 효율적일 것 같다.\n\n\u003cbr\u003e\n\n- 상태 관리 고민\n  - 필터와 할일 목록을 하나의 객체로 관리를 할지 분리할지 고민을 했다.\n    - 두 개의 성격이 완전히 다른 것 같아서 분리했다.\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ffivethreeeo%2Freact-practice-todolist","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Ffivethreeeo%2Freact-practice-todolist","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ffivethreeeo%2Freact-practice-todolist/lists"}