Skip to content

Latest commit

 

History

History
115 lines (76 loc) · 7.81 KB

README.md

File metadata and controls

115 lines (76 loc) · 7.81 KB

DingDong

목차

배포사이트

기술스택

TypeScript React emotion Badge MSW Badge React Query

배운점

검색어 자동완성 기능 구현

  • 검색어 자동완성 영상 미리보기
  • 구글 브라우저에서 한글의 경우 조합문자로 인한 KeyDown Event가 2번 실행되는 문제 발생 및 해결 -> 해결한 방법 ←

DragCarousel 기능 구현

무한 스크롤 기능 구현

  • 무한스크롤 영상 미리보기 무한스크롤720
  • Intersection Observer를 사용하여 무한스크롤 로직 구현

MSW를 활용한 API 모킹

  • 백엔드 개발자와의 협업 과정에서 api 제공 일정이 지연됨에 따라 프론트엔드 개발의 병목 현상을 가정하여 MSW API 모킹 작업 진행

페이지 간 이동 시 스크롤 위치 유지 문제 해결

  • 현재 페이지에서 스크롤을 통해 아래쪽 페이지에 있다가 다른 페이지로 넘어가면 맨위부터 시작하지 않고, 내려간 스크롤 위치로 넘어가 사용자 입장에서 불편한 문제 발생

  • pathname이 바뀔 때 window.scrollTo을 최상단으로 이동시켜 문제 해결

    const { pathname } = useLocation();
    
    useEffect(() => {
      window.scrollTo({ top: 0, behavior: 'smooth' });
    }, [pathname]);
    
  • 수정 전 화면-기록-2023-09-05-오후-1 39 29

  • 수정 후 화면-기록-2023-09-05-오후-1 41 52

Suspense를 활용하여 로딩 상태를 친화적으로 관리

  • Suspense를 통해 데이터를 비동기로 로딩하는 동안 '로딩 중...' 메시지를 표시하고, 데이터를 성공적으로 받아오면 화면을 렌더링하도록하여 사용자 친화적으로 로딩 상태를 관리했습니다.

화면-기록-2023-09-05-오후-2 04 12

ErrorBoundary를 활용하여 에러처리

  • ErrorBoundary를 활용하여 하위 트리에서 발생한 에러를 처리하고, 처리된 에러를 fallback 속성에 전달받은 컴포넌트로 처리했습니다. 화면-기록-2023-09-05-오후-3 57 34(1)

route 매개변수 사용시 문제발생 및 해결

  • 기본적으로 완전 다른 경로의 경우 준비중.. 페이지로 넘어가도록 구현했습니다. 하지만 :shopList로 받은 경우 즉 route 매개변수 사용의 경우 문제가 발생했습니다.

  • <Route path={'/category/:shopList'} element={<ShopCategoryPage />} />이런식으로 경로를 지정하고, /category/1인분아무경로로 이동 의 경로로 접속한 경우 문제없이 해당 경로로 이동하게 되는 문제가 발생했습니다.

  • 스크린샷 2023-09-05 오후 9 38 28

  • 문제해결

    • 아래와 같이 shopList의 Title에 포함되어 있지 않은 경우 404 경로로 이동시켰으며, replace:true 속성을 이용해 이전 기록으로 돌아가지 못하도록 했습니다.
    useEffect(() => {
      const shopNames = data?.map((item: CreateFoodCategoriesDataResponse) => item.title);
      if (shopNames && !shopNames.includes(shopList)) {
        navigate('/404', { replace: true });
        return;
      }
    }, [data, navigate, shopList]);
    

    화면-기록-2023-09-05-오후-9 42 54

고민해보기

비슷한 구조를 가진 컴포넌트 재활용

  • 비슷한 구조를 가지고 있고, 예를들어 3가지의 기능 차이 및 UI가 다를때 하나의 컴포넌트로 재사용할지 vs 3가지의 비슷하지만 다른 컴포넌트를 구성할지에 대해 고민해보았습니다. 블로그 보러가기 ←

같은 구조이지만 UI가 다른 컴포넌트 재활용

  • 같은 기능을 가지고 있고, UI만 다른경우 어떻게 처리를 할까? 고민을 했습니다.

    • 아래의 사진의 경우 비슷하지만 각각 다른 UI를 가지고 있습니다. 스크린샷 2023-09-05 오후 6 35 13

    • 3가지의 컴포넌트를 만들어야되나? prop로 받아서 재활용 할 순 없을까? 고민을 하던 중 props로 받아서 Size별로 다른 UI를 보여주도록 구현해봤습니다. 스크린샷 2023-09-05 오후 6 40 06

    • 단점은 코드가 너무 길어지는 문제가 발생합니다. 또한 현재 Size가 3가지 뿐이라 이렇게 했지만, 만약 Size가 여러개라면 Size별로 나타내는것 보다는 여러 컴포넌트를 만드는것이 더 효율적인 것 같습니다.