for문으로 만든 input 폼 jquery로 제어
본문
안녕하세요.
php로 for문을 만들어 동일한 input 폼을 다수 생성했습니다.
DB에 저장된 값을 가져오기에 생성되는 input 폼은 경우에 따라 상이합니다.
우선 코드를 한 번 보시면,
<?php
$sql = " select * from company_item_option where mb_id='{$member['mb_id']}' ";
$result = sql_query($sql);
for ($i=0; $row=sql_fetch_array($result); $i++) {
?>
<tr>
<td>
<input type="text" name="value_1[<?php echo $i;?>]" id="value_1" value="<?php echo $row['value_1'];?>">
</td>
<td>
<input type="text" name="value_2[<?php echo $i;?>]" id="value_2" value="<?php echo $row['value_2'];?>">
</td>
<td>
<input type="text" name="price[<?php echo $i;?>]" id="price" value="<?php echo $row['price'];?>">
</td>
<td>
<input type="text" name="quantity[<?php echo $i;?>]" id="quantity" value="<?php echo $row['quantity'];?>">
</td>
</tr>
<?php } ?>
... 이하 코드 생략
이런 형태로 DB 내용을 가져와 for문을 돌려 input 폼을 생성하는 구조입니다.
그런데 이렇게 생성된 폼을 jquery로 제어하는 과정에서 잘 안되는 부분이 있어
이렇게 질문을 올리게 되었습니다.
$(document).ready(function() {
$("#option_update").on("click", function() {
if ($("#price").val() < (-<?=$item_price?>)*0.5 || $("#price").val() > <?=$item_price?>*0.5) {
alert ("추가금액이 범위를 넘었습니다.");
$(this).focus();
return false;
}
});
});
예를 들어 위와 같은 코드로 id가 price인 폼을 제어하려고 했더니
폼이 x개인 경우(1개 이상) 가장 위에 첫번째 폼만 제어되고 나머지는 제어가 되지 않네요.
id는 중복이 허용되지 않는다고 해서 class로 변경해봤지만 마찬가지였습니다.
제가 원리를 모르고 있어서 그런건지 모르겠는데 어떻게 해결해야할지 감이 안오네요.
아시는 분의 소중한 답변 기다리겠습니다.
감사합니다.
!-->!-->
답변 1
<script>
$(document).ready(function() {
$("#option_update").on("click", function() {
$("input[name^=price]").each( function() {
if ($(this).val() < (-<?=$item_price?>)*0.5 || $(this).val() > <?=$item_price?>*0.5) {
alert ("추가금액이 범위를 넘었습니다.");
$(this).focus();
return false;
}
});
});
});
</script>