Skip to content
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

KDT5_김동해 #60

Open
wants to merge 3 commits into
base: main
Choose a base branch
from
Open

KDT5_김동해 #60

wants to merge 3 commits into from

Conversation

THEEASTSEA
Copy link

🎬 OMDb API를 활용한 영화 검색 사이트 'MovieMatrix'

배포

MovieMatrix


프리뷰

메인 페이지


기술스택

Vite Npm

HTML5 JAVASCRIPT


요구사항

❗ 필수

  • 영화 제목으로 검색이 가능해야 합니다!
  • 검색된 결과의 영화 목록이 출력돼야 합니다!
  • 단일 영화의 상세정보(제목, 개봉연도, 평점, 장르, 감독, 배우, 줄거리, 포스터 등)를 볼 수 있어야 합니다!
  • 실제 서비스로 배포하고 접근 가능한 링크를 추가해야 합니다.

❔ 선택

  • 한 번의 검색으로 영화 목록이 20개 이상 검색되도록 만들어보세요.
  • 영화 개봉연도로 검색할 수 있도록 만들어보세요.
  • 영화 목록을 검색하는 동안 로딩 애니메이션이 보이도록 만들어보세요.
  • 무한 스크롤 기능을 추가해서 추가 영화 목록을 볼 수 있도록 만들어보세요.
  • 영화 포스터가 없을 경우 대체 이미지를 출력하도록 만들어보세요.
  • 영화 상세정보가 출력되기 전에 로딩 애니메이션이 보이도록 만들어보세요.
  • 영화 상세정보 포스터를 고해상도로 출력해보세요. (실시간 이미지 리사이징)
  • 차별화가 가능하도록 프로젝트를 최대한 예쁘게 만들어보세요.
  • 영화와 관련된 기타기능도 고려해보세요.

기타기능

My Movie (마이 무비)

  • 영화를 검색 후 마음에 드는 영화의 상세 페이지에서 하트 버튼을 클릭할 경우 LocalStorage에 해당 영화의 정보가 저장되어 이후 'My Movie' 페이지에서 저장된 영화 리스트를 확인할 수 있도록 구현하였습니다.

프로젝트 리뷰

인사이트

  • 자바스크립트를 활용하여 각각의 개별 컴포넌트를 나누고 UI와 기능에 따라 필요한 컴포넌트를 임포트하여 사용하는 방법을 배울 수 있었습니다.

  • API를 활용하여 서버로부터 필요한 데이터를 요청하고 불러온 데이터를 쓰임에 따라 자바스크립트로 가공 및 활용하는 방법을 배울 수 있었습니다.

  • 라우터를 활용하여 URL에 따라 페이지를 나누고 예외 처리를 통해 404 페이지를 구현하는 방법을 배웠습니다.

  • 스토어 기능을 통해 필요한 데이터를 공통으로 관리하고 각각의 컴포넌트에서 활용하는 방법을 배웠습니다.

문제점

  • 미디어 쿼리 적용 : PC 비율에 맞게 제작된 CSS를 미디어 쿼리를 통해 모바일 레이아웃을 구성하는 과정에서 일부 항목이 제대로 적용되지 않는 문제가 있었습니다. 향후 프로젝트에 미디어 쿼리를 적용할 경우 모바일 레이아웃을 먼저 구현하는 순서로 진행해야 할 것 같습니다!

  • 뒤로가기 버튼 구현 : 영화 상세 페이지에서 이전 화면(검색 페이지)으로 이동하기 위해 '뒤로가기' 버튼을 구현하였으나, 브라우저의 뒤로가기와 같은 기본 방식으로, 이전 페이지가 검색 페이지가 아닐 경우 기능이 제대로 작동하지 않는 문제가 있습니다. (이전 페이지와는 상관 없이 현재 검색 내역 페이지로 이동할 수 있는 방법이 있을까요?)

Copy link

@sangheon-kim sangheon-kim left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

부족한 부분 코멘트 해드렸습니다

}
element.addEventListener('click', () => setCounter(counter + 1))
setCounter(0)
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

이건 왜만드신걸까요?

<head>
<meta charset="UTF-8" />
<link rel="icon" type="image/svg+xml"
href="" />

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

흠... 굳이 이렇게 인코딩한걸 넣은 이유가 있나요?

</div>
`

setupCounter(document.querySelector('#counter'))

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

counter는 주제랑 맞지 않는데 파일로 남겨두신 이유가 있을까요?

const routerView = document.createElement('router-view')
const header = new TheHeader().el
const footer = new TheFooter().el
this.el.append(header, routerView, footer)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

innerHTML을 안쓰고 이렇게 쓰신 이유가 있나요?

this.el.style.backgroundImage = `url(${movie.Poster})`
this.el.innerHTML = /*html*/ `
<div class="info">
<div class="type">${movie.Type.toUpperCase()}</div>

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

반대로 또 위에는 append로 써놓고 여기는 INNERHTML을 쓰신것도 이해가 안됩니다

}
})
}
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

이벤트 핸들러 따로 분리해서 파악이 가능하게 해주세요.

</a>
</nav>
`
this.el.classList.add('header')

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

마지막에 header 클래스를 넣으신 이유가 있나요?

// 구독할상태이름: [실행할콜백1, 실행할콜백2]
// movies: [cb, cb, cb],
// message: [cb]
// }

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

구독 해제하는건 어딨나요?

@@ -0,0 +1,7 @@
import App from './App.js'

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

한번만 쓰일거라면 싱글턴으로 정의해도 되지않을까요ㅕ?
굳이 재사용할게 아닌데 new 연산자를 쓸 수 있게 하신 이유는 뭘까요?

</a>
</div>
<button class="delete" data-title="${movie.Title}">delete</button>
`

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fragment 노드에 담아서 마지막에 fragment 노드를 append 해주는게 더 좋을 것 같아요

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants