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

[2주차] 햄식이의 장바구니 #2

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

Conversation

NamJwong
Copy link
Member

@NamJwong NamJwong commented Apr 22, 2022

✨ 구현 기능 명세

  • 기본 과제
  • 심화 과제 - 차차 하겠습니다!

[기본 과제] written by 웹파짱

  1. 햄버거 카드를 클릭하면 장바구니에 해당 버거이름의 장바구니 요소가 추가돼요.
    1. click 이벤트를 사용해요.
    2. 각 장바구니의 요소는 다음의 구성을 가져야해요.
      1. 버거이름 수량 가격 삭제버튼
  2. 이미 장바구니에 있는 버거를 클릭하면 새로운 요소가 추가되는게 아니라 수량이 늘어나야해요.
  3. 삭제 버튼을 누르면 해당 요소가 삭제돼요.
  4. 장바구니의 요소가 추가/삭제 될 때마다 누적금액도 변동되어야해요.
    1. string과 number의 + * 연산에 주의하세요.
  5. 장바구니의 취소하기 버튼을 누르면 모든 장바구니를 비워주세요.
  6. 주문하기 버튼 을 누르면 정말 주문하시겠어요? 모달을 띄워주세요.
    1. 를 누르면 a 태그를 사용해서 완료 페이지로 이동해주세요.
    2. 아니오를 누르면 모달을 다시 닫아주세요.

🎁 PR Point

일단,, 이번 주차 과제는 벼락치기로 했기 때문에 구현에만 집중해서 리팩토링 할 부분이 많을 것입니다 ,,
마구마구 의견 남겨주시면 감사하겠습니다 ㅎ ㅡ ㅎ (물론 저도 다시 찬찬히 보면서 리팩토링 하려고 하고 있습니다 ㅎ)
제안하고 싶은 구현 방식이나 네이밍, 궁금한 점 등등 자유롭게 남겨주세요 !

< article.card의 id를 생성한 방식에 대해!>
제가 작성한 html을 토대로 하면 article.card의 innerText가 아래와 같이 설정됩니다.
KakaoTalk_Photo_2022-04-22-23-34-58
또 햄버거들의 가격을 첫 번째 햄버거의 가격을 1000원 두번쨰 햄버거의 가격을 2000원 즉, index * 1000원으로 설정해줬기 때문에 가능한 방식입니다
즉, html 구조를 이렇게 짜고 데이터를 이렇게 넣어줘야만 가능한 방식이에요!
따라서 실제 이러한 서비스를 구현한다면 이런 방식을 안쓰겠죠! 그리고 직관적인 방식도 아니라 생각됩니다
그런데 사실 어차피 id값은 보통 서버에서 부여해주기도 하고, html에 직접 일일이 id를 달아주기 번거로웠고, 안해본 방식으로 DOM을 다뤄보고 싶었다는 요 3가지 이유로 이렇게 구현했습니다

저는 바닐라 자스 할 때 여태껏 html 엘리먼트 받아온 변수들을 그 파일의 가장 상단에 선언 및 할당해놓고 썼었어요 (별 이유 없는 습관이에요)
그런데 이번에 굳이 고럴 필요가 없다고 첨 생각하게 됐습니다
고민할 시간이 부족해서 일단 예전처럼 가장 상단에 다 선언해놨는데 리팩토링 하면서 적절한 위치를 찾아보겠습니다!

😭 어려웠던 점

딱히 없었습니다!

😎 구현 결과물

배포 링크

@github-actions
Copy link

오늘도 할할놀놀을 몸소 실천 중인 웹파트원 ! 화이팅 :)
과제 레퍼런스 참고해서 빠트린 부분은 없는 지 체크해볼까요?

@NamJwong NamJwong changed the title Assignment 2 2 [2주차] 햄식이의 장바구니 Apr 22, 2022
@NamJwong NamJwong requested review from aeuna and choiyoorim April 22, 2022 14:47
@NamJwong NamJwong self-assigned this Apr 22, 2022
@NamJwong NamJwong added the 2️⃣ 2주차 2주차 과제에요. label Apr 22, 2022
Copy link

@aeuna aeuna left a comment

Choose a reason for hiding this comment

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

버거 아이템 리스트에 수량, id, 이름, 가격 넣어 구현 하시니까 확실히 깔끔한것 같아요!
저도 리팩토링 할때 참고해보겠습니다! js문법들도 유용하게 잘 사용하신게 보여요! 과제 수고하셨습니다 👍
3주차 과제는 후딱빨리 리뷰 하겠습니다!!

@@ -0,0 +1,121 @@
'use strict';
Copy link

@aeuna aeuna May 3, 2022

Choose a reason for hiding this comment

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

이 부분은 어떤 역할을 하나요?


const openModal = () => {
modalDiv.style.visibility = 'visible';
body.style.overflow = 'hidden';
Copy link

@aeuna aeuna May 3, 2022

Choose a reason for hiding this comment

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

모달 div의 display 속성을 건들지 않고 visibility 속성을 이용하신 이유가 있나용?


const setSum = () => {
cartSumDiv.innerText = addedBurgerList
.reduce((sum, burger) => sum + burger.quantity * burger.price, 0)
Copy link

Choose a reason for hiding this comment

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

reduce함수를 사용하시다니 배워갑니다!! 👍

const getBurgerFromInnerText = (innerText) => {
const innerTextList = innerText.split('\n');
return {
id: makeId(parsePriceToNumber(innerTextList[1])),
Copy link

Choose a reason for hiding this comment

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

혹시 이렇게 하면 id가 중복될 경우는 생기지 않나요?

const modalDiv = document.querySelector('.modal-background');
const modalNoButton = document.querySelector('.modal__button-wrapper > button');

let addedBurgerList = [];
Copy link

Choose a reason for hiding this comment

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

저는 이 list에 카트에 담긴 버거의 이름만 담아줬는데, 이외의 정보도 담아서 유용하게 코드를 짤 수 있다는 점을 생각을 못했네요! 배워갑니다!

nameDiv.innerText = newBurger.name;
const input = document.createElement('input');
input.value = 1;
input.setAttribute('readonly', true);
Copy link

@aeuna aeuna May 3, 2022

Choose a reason for hiding this comment

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

readonly 속성이 궁금해서 구글링해보니 => input type="text" 에만 가능. 사용자는 value 값을 변경할 수 없음. 이라 나오네요!
사용자가 value 속성은 변경을 못하게 하는거군요! 참고하겠습니다 :)

@github-actions
Copy link

github-actions bot commented May 6, 2022

오늘도 할할놀놀을 몸소 실천 중인 웹파트원 ! 화이팅 :)
과제 레퍼런스 참고해서 빠트린 부분은 없는 지 체크해볼까요?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
2️⃣ 2주차 2주차 과제에요.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants