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

home2 게시판 JavaScript, TS 게시판 웹개발 기능대회 합계 질문

웹개발 기능대회 합계 질문

4 글 보임 - 1 에서 4 까지 (총 4 중에서)
  • 글쓴이
  • #23046

    aef32
    참가자


    위 사진에서 개별 상품 가격의 합을 구하려고 합니다.


     

    $('.card-img').droppable({
        drop: function(event, ui) {
            var item = $(ui.draggable);
            var index = item.attr('data-index');
            var img = item.find('img');
            var productName = item.find('.product-title').text();
            var brandName = item.find('.product-brand').text();
            var price = item.find('.product-price').text();
           
            var 장바구니상품 = $(`
            <div class="card-deck">
                <div class="card mb-3" style="max-width: 540px;" data-index="${index}">
                    <div class="row no-gutters">
                        <div class="col-md-4 overflow-hidden">
                            <img src="${img.attr('src')}" class="card-img h-100 w-auto" alt="${productName}" title="${productName}">
                        </div>
                        <div class="col-md-7">
                            <div class="card-body">
                            <h5 class="card-title product-name">${productName}</h5>
                            <p class="card-text brand-name">${brandName}</p>
                            <p class="card-text"><small class="text-muted price">${price}</small></p>
                            <p class="card-text">
                                <div class="input-group input-group-sm mb-3">
                                    <div class="input-group-prepend">
                                        <span class="input-group-text" id="inputGroup-sizing-sm-${index}">수량</span>
                                    </div>
                                    <input type="number" min="1" value="1" class="form-control number" >
                                </div>
                            </p>
                            <p class="card-text">합계 <span class="sum">${price}</span>원</p>
                            </div>
                        </div>
                        <button type="button" class="col-md-1 btn-delete">X</button>
                    </div>
                </div>
            </div>
            `);

            $('.basket-list').append(장바구니상품);

            장바구니상품.find('.btn-delete').on('click', function(){
                장바구니상품.remove()
            })

            $('.number').change(function(){
                    var 물건개수 = $('.number').val();

                    var 단일물건합계 = 물건개수 * price

                    $('.sum').html(단일물건합계)        })

     

    이에 대해 가장 아래에 있는 코드를 작성했는데

    품목이 하나일 때는 온전히 작동을 했으나 품목이 두개 일 때 버그가 났습니다.

    어떻게 접근해야하는 지 힌트를 얻을 수 있을까요?

    #23066

    codingapple
    키 마스터

    var 물건개수 = $('.number').val();

    .number라고 찾으면 장바구니에 상품이 2개 이상 있어도 맨 윗 상품만 찾아줄듯요  

    var 물건개수 = $(this).val() 일단 이런 식으로 써봅시다 

    #23098

    aef32
    참가자

    this를 활용해서 문제는 해결했습니다.

    단순히 this만 사용해야하는 것이 아니라 find함수를 같이 써야 기능이 동작했는데

    중복되는 class가 없는데도 왜 find를 사용해야하는 지 궁금합니다.

     

    장바구니상품.find('.number').change(function(){
                    var 단일물건합계 = $(this).val() * price

                    장바구니상품.find('.sum').html(단일물건합계)  
            })

     

     

    #23107

    codingapple
    키 마스터

    find는 특정 html 덩어리에서만 찾아달라는 소리인데

    아직 html 생성이 덜되어서 .number가 없거나

    .number가 다른데 또 있거나 그런 경우일수도 있겠군요

4 글 보임 - 1 에서 4 까지 (총 4 중에서)
  • 답변은 로그인 후 가능합니다.

About

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

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

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