Skip to content

Hoya-kim/Gotcha

Repository files navigation

Gotcha! - 갓쨔

🥇 개요

K-netfilx, Watcha-왓챠 프론트 클론 프로젝트입니다.
Watcha가 웹 표준접근성을 준수하고 있는지, 성능부분에서 놓치고 있는 부분이 있는지 분석 및 확인하여, 개선하는 것을 목표로 합니다. 🎯


🚀 프로젝트 사용기술

  • HTML5 (customElement, ...)
  • CSS3 (Sass, PostCSS)
  • JavaScript
  • webpack, babel

🌟 탄생배경

✅ 주제 선정 배경

  1. 미니 프로젝트를 시작했을때, 새로 페이지를 디자인해서 만들지 아니면 클론코딩을 할 지 고민을 많이했다. 사실 우리 팀만의 독자적인 사이트를 만들어보고싶었지만 너무나도 짧은 시간에 디자인에 너무 많은 시간을 빼앗길것 같다는 생각에 클론 코딩을 하기로 결정했다. 대신, 수업시간에 배웠던 것을 최대한 많이 활용하여 접근성과 성능을 개선시켜보기로 목표를 잡았다.
  2. 왓챠 팝콘먹다 왓챠 1개월 무료 감상권 쿠폰(?) 뽑고 팀원들이랑 너무 들떴다. 그래서 왓챠를 보려고하는데 로딩 시간이 너무 길어서 화가난 우리는 왓챠 클론 코딩을 하며 이런 부분을 우리가 개선시키고자했다.
  3. 갓챠의 최종 목표는 접근성과 성능을 모두 향상시켜 국내 유일의 OTT 서비스를 제공하는 것이다.

📆 프로젝트 기간

21.08.27 ~ 21.09.03

  • 2021.08.27 : 주제 선정, 로고 제작, CSS 설계 기법 정리, 칸반차트 생성
  • 2021.08.28~08.30 : 왓챠와 넷플릭스(경쟁사) 페이지 (성능 및 접근석 분석), 공통 UI 마크업 및 스타일링 작업, 깃 컨벤션 및 코딩 컨벤션 작성
  • 2021.08.31~09.01 : 개별 UI 마크업 및 스타일링, JS 작업
  • 2021.09.02 : 코드 리뷰 및 리펙토링, 발표 준비하기 (PPT 및 대본 준비), KPT 작성
  • 2021.09.03 : 발표


📘 commit convention

$ git commit

[type]: [subject] - [Issue #num]

[body]

[type] : commit의 타입

[subject] : commit의 제목

[body] : commit의 내용

[Issue] : 이슈 연결

  • 제목과 본문은 한 줄을 띄워 분리합니다
  • 제목은 간략하게 간추립니다 (기왕이면 50자이내)
  • 제목 첫 글자는 대문자
  • 제목 끝에 .금지

📗 type 종류

feat: 새로운 기능을 추가
fix: 버그 수정
style: 코드 포맷팅, 세미콜론 추가 등 코드 변경이 없는 경우
docs: 문서 수정
refactor: 코드 리펙토링
chore: 패키지 매니저 등 빌드 관련 설정 수정
test: 테스트 코드 추가

📙 Issue #num

- Issue #13    # 평소 커밋시 사용 - 기능에 해당하는 이슈에 연결

- Close #14    # 이슈를 닫을 때 (일반 개발 이슈)
- Fix #15    # 이슈를 닫을 때 (버그 픽스 이슈)
- Resolve #16    # 문의나 요청 사항 대응
이건 뭔가요?
  • 해당 구문이 commit에 들어가면 github이 자동으로 인식해 이슈를 종료합니다.

참고자료



📌 브랜칭 및 PR 전략

🪄 git-flow를 경량화한 형태를 사용

  • git-flow형태를 따르되 규모가 작은 토이 프로젝트이므로, 경량화한 형태를 사용

main : 배포 이외 사용금지

develop : 기능단위 feature들이 merge될 브랜치

feat- : 기능별 브랜치 ( ex, feat-common : 공통 기능 개발 브랜치 )

fix- : 버그 fix or hot fix시 사용할 브랜치

📤 Pull Request 전략

upstream-repo: developforked-repo: develop

  1. 각자의 origin에서 기능 개발 완료 후 devlop으로 머지
  2. 각자의 develop에서 테스트 후 이상이 없으면 upstream의 develop으로 PR


📍 기존 서비스의 문제점

  1. 성능 점수는 예상과도 같이 낮았다. (로딩속도가 10~15초 정도라서 web core vitals의 LCP 지표에 한참 미치지 못했다)
  2. 접근성 점수는 높음에도 불구하고 마크업은 전혀 시멘틱하지못했다 (div와 span이 대다수인 마크업)클래스 이름 또한 불분명하여 해당 마크업 구조를 전혀 파악할 수 없었다.
  3. 탭 키 또한 논리적으로 이동하지않았고, 중간에 outline이 사라져 어디에 탭이 위치한지 파악하기도 힘들었고 어떤 부분은 탭키로 다가갈수도 없었다.


🖼 Preview

1. 메인 페이지

______________4.mp4
공통영역
컨텐츠 영역

GOTCHA의 작품들을 한눈에 볼 수 있는 페이지입니다.
접근성을 위해 키보드로 모든 컨텐츠 탐색을 용이하게 하고 저시력자를 위해 어디 부분을 탐색하고 있는지 알 수 있게 했습니다.
스크린 리더기를 사용해야 하는 사용자를 위해서도 최대한 시멘틱적인 요소와 속성들을 사용하고자 했습니다.
이미지가 많이 들어가기 때문에 최신 이미지 포맷을 사용하면서 하위 브라우저에서도 호환 가능하도록 여러 포맷을 제공하였습니다. 메인 배너 부분과 작품들을 hover했을 때 동적인 효과를 주어 사용자에게 즐거움을 주고자 하였습니다.


2. 뷰 페이지

______________2.mp4

작품에 관해 다양한 정보를 제공하는 페이지로 사용자가 정보를 한눈에 알아볼수있도록 탭 메뉴로 구성했습니다.
시멘틱한 마크업을 위하여 별점 부분은 데스크탑 기준, 밑에 설명 부분은 모바일 기준으로 작성했습니다. 또한, 모바일 환경에서는 탭이 사라지기때문에 탭 기능을 가진 태그를 사용하기보다는 div에 wai-aria의 role을 주며 접근성을 지키고자 했습니다.


3. 평가하기 페이지

______________3.mp4

각 작품들에 대한 평가를 별점으로 남길 수 있는 페이지입니다.
최대한 기존 watcha 서비스의 UI를 유지하면서 페이지의 웹 표준과 접근성을 준수하고 성능을 개선할 수 있도록 하였습니다.
tab-index를 요소에 추가하여, 키보드 접근성에 대한 향상을 꾀했습니다.



📝 프로젝트 설계 기록


🥇 발표 slide



🎓 Team

김정호 박바름 박지영 박태준
@Hoya-kim @congaweb @kkdd0757 @joker77z

About

K-netfilx 와챠 클론 프로젝트

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •