-
Notifications
You must be signed in to change notification settings - Fork 46
[1팀 김민석] Chapter 3-3 기능 중심 아키텍처와 프로젝트 폴더 구조 #27
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Open
kju1018
wants to merge
39
commits into
hanghae-plus:main
Choose a base branch
from
kju1018:main
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Conversation
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
과제 체크포인트
배포 링크입니다! https://kju1018.github.io/front_7th_chapter3-3/
기본과제
목표 : 전역상태관리를 이용한 적절한 분리와 계층에 대한 이해를 통한 FSD 폴더 구조 적용하기
체크포인트
심화과제
목표: 서버상태관리 도구인 TanstackQuery를 이용하여 비동기코드를 선언적인 함수형 프로그래밍으로 작성하기
체크포인트
최종과제
과제 셀프회고
이번 과제를 통해 이전에 비해 새롭게 알게 된 점이 있다면 적어주세요.
사실 FSD라는 개념도 최근에야 알게 되었고, entities, features 등 레이어를 나누는 기준에 대해서는 아직도 모호하게 느껴지는 부분이 많습니다.
이번 과제를 통해 FSD 아키텍처라는 구조가 존재한다는 점, 그리고 단방향 의존성과 단일 책임을 가져야 한다는 이론적 배경을 새롭게 이해할 수 있었습니다.
본인이 과제를 하면서 가장 애쓰려고 노력했던 부분은 무엇인가요?
결과적으로 완벽하게 구현하지는 못했지만,
이번 과제에서 제가 가장 노력했던 부분은 누구나 납득할 수 있는 폴더 구조와 컴포넌트 분리를 시도하는 것이었고,
각각의 레이어가 어떤 책임을 가지는지 최대한 이해해보려는 과정이었습니다.
아직은 막연하다거나 더 고민이 필요한 부분을 적어주세요.
아직은 features와 entities를 나누는 기준이 어느 정도 이해된 것 같으면서도, 여전히 많이 헷갈리는 상태입니다.
처음에는 명확하게 “이건 features에 가깝다”고 느꼈던 부분도, 시간이 지나 다시 보면 entities에 더 어울리는 것처럼 보이기도 했습니다.
전체적으로 정리가 잘 안되어있어서 모든게 막연한느낌? 입니다.
이번에 배운 내용 중을 통해 앞으로 개발에 어떻게 적용해보고 싶은지 적어주세요.
아직은 이 구조를 바로 실무에 적용하겠다고 말할 만큼 충분히 이해한 단계는 아니지만,
우선 개인 프로젝트를 진행하면서 한 번 적용해보고 싶다는 생각이 들었습니다.
그리고 이후 재직 중인 회사에서 폴더 구조를 개편하거나 신규 프로젝트를 진행하게 된다면,
그때 FSD 구조를 도입해보는 것도 충분히 시도해볼 만하다고 느꼈습니다.
챕터 셀프회고
클린코드: 읽기 좋고 유지보수하기 좋은 코드 만들기
과제를 본격적으로 시작하려고 코드를 처음 봤을때 사실 '어디서부터 뭘 해야하지?' 라는 생각에 막막했던거같습니다.
우선 제가 생각하는 읽기 좋은 코드는, 코드를 처음 보았을 때 특별한 불편함이 느껴지지 않고, 내용을 이해하기 위해 굳이 여러 번 다시 읽지 않아도 되는 코드라고 생각합니다.
제가 생각하는 유지보수하기 쉬운 코드는, 변경 사항이 생겼을 때 어디를 수정해야 할지가 바로 떠오르는 코드라고 생각합니다.
반대로, 수정이 필요함에도 불구하고 어디를 고쳐야 할지 찾기 어려운 코드라면, 그만큼 유지보수가 어려운 코드라고 느껴집니다.
결합도 낮추기: 디자인 패턴, 순수함수, 컴포넌트 분리, 전역상태 관리
처음에는 features에 posts, comments, users 폴더를 만들고 그 안에 model, ui, api를 구성했지만,
이후 features/posts/add-post처럼 사용자 행동 단위로 폴더 구조를 나누면서 구조가 훨씬 직관적으로 느껴졌습니다.
폴더 구조만 보더라도 어떤 동작과 관련된 로직이 들어 있는지 바로 파악할 수 있었고,
기능 단위로 사고하게 되는 계기가 되었습니다.
응집도 높이기: 서버상태관리, 폴더 구조
이번 과제에서는 폴더 구조를 미리 찾아보고 시작하기보다는,
이론을 먼저 이해한 뒤 제가 느낀 방향대로 구조를 잡아보았습니다.
처음에는 features 아래에 posts, comments, users 폴더를 만들고 그 안에 model, ui, api를 구성했지만,
점점 하나의 폴더에 많은 기능이 모이면서 구조가 복잡하게 느껴졌습니다.
이후 사용자 행동 단위로 폴더 구조를 다시 나누면서,
폴더만 보아도 어떤 기능을 담당하는지 한눈에 파악할 수 있었고
이전보다 훨씬 직관적인 구조라고 느꼈습니다.
리뷰 받고 싶은 내용이나 궁금한 것에 대한 질문
아직 제가 FSD에 대한 이해가 충분하지 않아서 그렇게 느끼는 것일 수도 있지만,
FSD 아키텍처를 적용하다 보면 분명 경계가 애매하거나 모호하게 느껴지는 지점들이 존재한다고 생각했습니다.
이런 경우에 코치님께서는 어떤 기준으로 레이어를 나누시는지 궁금하고,명확하게 판단하기 어려운 상황에서는레이어의 정합성보다도 일관성을 유지하는 것이 더 중요하다고 보시는지 궁금합니다!