• 로그인
  • 장바구니에 상품이 없습니다.

home2 게시판 JavaScript, TS 게시판 장바구니 기능 응용 문제2

장바구니 기능 응용 문제2

  • 이 주제에는 2개 답변, 2명 참여가 있으며 한지수2 년 전에 전에 마지막으로 업데이트했습니다.
3 글 보임 - 1 에서 3 까지 (총 3 중에서)
  • 글쓴이
  • #86235

    한지수
    참가자
    2. 아니면 같은 상품 구매 누르면 상품 갯수가 올라가게?
    
    응용 문제 코드 짜기 성공은 했는데 두 가지 경우에서 하나는 잘 작동하고 
    하나는 안되는 이유를 모르겠습니다!
    
    잘되는 코드
    var 검사 =[]
        $(".buy").on('click', (e) => {
          var title=$(e.target).siblings('h5').html();
          var product = {상품명:title , 갯수:1}
          if(localStorage.getItem('cart') != null){
            var 꺼낸거 = JSON.parse(localStorage.cart);
            꺼낸거.forEach((item)=>{
              if(검사.includes(title)){
                  if(item.상품명 == title){
                    item.갯수++
                    localStorage.setItem('cart',JSON.stringify(꺼낸거));
                  }              
              }else{
                검사.push(title);
                꺼낸거.push(product);
                localStorage.setItem('cart',JSON.stringify(꺼낸거));
              }
            })
          }else{
            localStorage.setItem('cart',JSON.stringify());
            검사.push(title);
          }
        })
    
    제품이 중복 저장되는 코드
    다른 부분은 잘되는 코드와 동일하며 forEach에서 if문의 조건만 다르고 로컬에는 이런식으로 저장됩니다.
    캡처
    
    if(검사.includes(title) && item.상품명 == title){
                item.갯수++
                localStorage.setItem('cart',JSON.stringify(꺼낸거));
              }else{
                검사.push(title);
                꺼낸거.push(product);
                localStorage.setItem('cart',JSON.stringify(꺼낸거));
              }
    
    같은 조건인데 왜 if문안에 if문으로 쓸 때는 실행이 잘되고 
    && item.상품명 == title을 추가해 한번에 조건을 쓰면 안되는지 이해가 잘 안돼요ㅠㅠ
    #86269

    codingapple
    키 마스터
    근데 그 전에 forEach 반복문 쓰면 
    장바구니에 상품이 100개 있으면 else문도 99번 실행되어서 상품이 99개 추가될듯요
    #86495

    한지수
    참가자
    find가 배열을 반환하는 줄 알고 계속 find써도 계속 안되길래 
    forEach로 했을 때 어찌저찌 돼서 코딩 짜본건데 방향이 완전 틀렸었네요ㅠ 
    find 요소 반환 절대 못까먹을것같습니다 감사합니다ㅎㅎ 
    
    캡처
    
     
    
     
3 글 보임 - 1 에서 3 까지 (총 3 중에서)
  • 답변은 로그인 후 가능합니다.

About

현재 월 700명 신규수강중입니다.

  (09:00~20:00) 빠른 상담은 카톡 플러스친구 코딩애플 (링크)
  admin@codingapple.com
  이용약관
ⓒ Codingapple, 강의 예제, 영상 복제 금지
top

© Codingapple, All rights reserved. 슈퍼로켓 에듀케이션 / 서울특별시 강동구 고덕로 19길 30 / 사업자등록번호 : 212-26-14752 온라인 교육학원업 / 통신판매업신고번호 : 제 2017-서울강동-0002 호 / 개인정보관리자 : 박종흠