Skip to content

Latest commit

 

History

History
125 lines (97 loc) · 5.85 KB

README.md

File metadata and controls

125 lines (97 loc) · 5.85 KB

Hyeonstagram Client
React Hooks Apollo platform

🔥 Motivation

인스타그램을 클론코딩하면서 React와 Hooks을 깊이 있게 이해하고 GraphQL과 Prisma을 공부하여 풀스택 개발을 하기 위해 프로젝트를 시작하였습니다.

서비스 소개

Instagram 풀스택 클론코딩 프로젝트

  • 온라인 사진 공유 및 소셜 네트워킹 서비스
  • 인스타그램의 프론트엔드, 백엔드 모두 클론 코딩하여 사진 업로드, 피드, Infinite Scroll, 포스팅/유저 검색, 댓글, 좋아요, 팔로잉, Skeleton loading 등 인스타그램의 주요 기능들을 구현하였습니다.

UI

1) 메인 피드

Feed mov

  • 좋아요 / 좋아요 취소
    • 좋아요 쿼리 요청을 보내기 전 Frontend에서 먼저 좋아요 처리 ⇒ 반응속도 Up
  • 댓글 작성
  • 이미지 슬라이딩
    • CSS translateX + transition 를 이용하여 슬라이딩 구현

2) 무한 스크롤 (Infinite scroll)

Infinity Scroll mov

  • Infinity Scroll
    • Observer 를 이용해 맨 아래 게시물 감지
    • ⇒ 서버에 offset과 limit 를 parameter로 전달하여 추가 피드 데이터 가져옴
  • 마지막 게시물 게시물 도달 시 안내 메세지
    • Toastify 사용

3) 회원가입 & 로그인

1

[회원가입]
2

[로그인]
  • 이메일 인증 코드 방식 로그인
  • 회원가입
    • Nodemailer 사용

4) Skeleton loading

1

[피드]
2

[유저 홈]
  • 쿼리 데이터 로딩
  • 이미지 리소스 로딩

5) 유저 홈

1

[유저 홈]
2

[반응형]
  • 게시글 마우스 hover시 좋아요, 댓글 오버레이
  • 부분 반응형 디자인 (게시글 사이 gap)
    • 미디어 쿼리 이용

6) Following & Unfollowing

1

[Following]
2

[Unfollowing]
  • 피드에 Following 한 사람들의 게시물만 보여짐
  • Unfollow 하면 피드에 해당 사람의 게시물이 사라짐

활용기술

  • Hooks: 함수형 컴포넌트의 React State와 생명주기 관리를 도와주는 모듈로 기존의 함수형 컴포넌트에서 할 수 없었던 다양한 작업을 할 수 있게 도와줍니다. (클래스형 컴포넌트 기능 거의 대부분을 대체가능)
  • Styled-component: CSS 파일 없이 자바스크립트 안에서 CSS 작업을 할 수있게 도와주는 모듈로 HTML element + CSS + Javascript 코드를 Component로 캡슐화시켜 코드를 관리하기 용이하도록 도와준다. (클래스 기반 Component 스타일링 대체)
  • Apollo: GraphQL의 클라이언트 라이브러리 중 하나로 GraphQL 상태 관리 플랫폼입니다.
  • Axios: 파일 업로드를 처리하기 위해 도입한 HTTP 클라이언트 라이브러리로써, 비동기 방식으로 Node.js 서버에 HTTP 데이터 요청을 실행합니다. (파일 관리에 있어서는 RESTfull 방식이 GraphQL 방식보다 효과적)
  • Sass: CSS의 유지보수의 불편함을 개선하여 효율적인 스타일링을 도와주는 라이브러리입니다.
  • Intersection Observer: 기존 Scroll Event로 Infinite Scroll을 구현하면 엘리먼트의 offset을 구하기 위해 불필요한 함수 호출과 매번 layout을 새로 그려 성능의 문제가 발생하게 되는 데, Intersection Observer는 타겟 엘리먼트와, 타겟 엘리먼트의 부모나 뷰포트가 교차하는 부분의 변화를 비동기적으로 관찰하여 이러한 문제점을 해결해준다.
  • Toastify: Notification, Alert를 쉽고 예쁘게 처리하도록 도와준다.