-
글쓴이글
-
2021년 12월 27일 16:58 #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(단일물건합계) })
이에 대해 가장 아래에 있는 코드를 작성했는데
품목이 하나일 때는 온전히 작동을 했으나 품목이 두개 일 때 버그가 났습니다.
어떻게 접근해야하는 지 힌트를 얻을 수 있을까요?
2021년 12월 27일 20:35 #23066
codingapple키 마스터var 물건개수 = $('.number').val();
.number라고 찾으면 장바구니에 상품이 2개 이상 있어도 맨 윗 상품만 찾아줄듯요
var 물건개수 = $(this).val() 일단 이런 식으로 써봅시다
2021년 12월 28일 09:33 #23098
aef32참가자this를 활용해서 문제는 해결했습니다.
단순히 this만 사용해야하는 것이 아니라 find함수를 같이 써야 기능이 동작했는데
중복되는 class가 없는데도 왜 find를 사용해야하는 지 궁금합니다.
장바구니상품.find('.number').change(function(){
var 단일물건합계 = $(this).val() * price장바구니상품.find('.sum').html(단일물건합계)
})2021년 12월 28일 10:16 #23107
codingapple키 마스터find는 특정 html 덩어리에서만 찾아달라는 소리인데
아직 html 생성이 덜되어서 .number가 없거나
.number가 다른데 또 있거나 그런 경우일수도 있겠군요
-
글쓴이글
- 답변은 로그인 후 가능합니다.