테스트 사이트 - 개발 중인 베타 버전입니다

for문으로 만든 input 폼 jquery로 제어 채택완료

케레니스 8년 전 조회 5,315

안녕하세요.

 

php로 for문을 만들어 동일한 input 폼을 다수 생성했습니다.

DB에 저장된 값을 가져오기에 생성되는 input 폼은 경우에 따라 상이합니다.

우선 코드를 한 번 보시면,

</p><p><?php</p><p>   $sql = " select * from company_item_option where mb_id='{$member['mb_id']}' ";</p><p>   $result = sql_query($sql);</p><p>   for ($i=0; $row=sql_fetch_array($result); $i++) {</p><p>?></p><p><span style="font-size: 11pt; line-height: 1.5;">     <tr></span></p><p>       <td></p><p>          <input type="text" name="value_1[<?php echo $i;?>]" id="value_1" value="<?php echo $row['value_1'];?>"></p><p>       </td></p><p>       <td></p><p>          <input type="text" name="value_2[<?php echo $i;?>]" id="value_2" value="<?php echo $row['value_2'];?>"></p><p>       </td></p><p>       <td></p><p>          <input type="text" name="price[<?php echo $i;?>]" id="price" value="<?php echo $row['price'];?>"></p><p>       </td></p><p>       <td></p><p>          <input type="text" name="quantity[<?php echo $i;?>]" id="quantity" value="<?php echo $row['quantity'];?>"></p><p>       </td></p><p>     </tr></p><p><?php } ?></p><p><span style="font-size: 11pt; line-height: 1.5;">... 이하 코드 생략</span> </p><p><span style="font-size: 11pt; line-height: 1.5;">

 

이런 형태로 DB 내용을 가져와 for문을 돌려 input 폼을 생성하는 구조입니다.

그런데 이렇게 생성된 폼을 jquery로 제어하는 과정에서 잘 안되는 부분이 있어

이렇게 질문을 올리게 되었습니다.

 

</p><p>$(document).ready(function() {</p><p>  $("#option_update").on("click", function() {</p><p>    if ($("#price").val() < (-<?=$item_price?>)*0.5 || $("#price").val() > <?=$item_price?>*0.5) {</p><p>        alert ("추가금액이 범위를 넘었습니다.");</p><p>        $(this).focus();</p><p>        return false;</p><p>    }</p><p>  });</p><p>});</p><p>

 

예를 들어 위와 같은 코드로 id가 price인 폼을 제어하려고 했더니

폼이 x개인 경우(1개 이상) 가장 위에 첫번째 폼만 제어되고 나머지는 제어가 되지 않네요.

id는 중복이 허용되지 않는다고 해서 class로 변경해봤지만 마찬가지였습니다.

 

제가 원리를 모르고 있어서 그런건지 모르겠는데 어떻게 해결해야할지 감이 안오네요.

아시는 분의 소중한 답변 기다리겠습니다.

 

감사합니다.

 

댓글을 작성하려면 로그인이 필요합니다.

답변 1개

채택된 답변
+20 포인트
8년 전

로그인 후 평가할 수 있습니다

답변에 대한 댓글 1개

케레니스
8년 전
소중한 답변 감사드립니다.
적용해보니 잘 됩니다. 정말 감사드립니다.

그런데 하나 문제가 발생한 것이..
alert은 뜨는데 확인을 누르면 그 다음의 focus와 return false가 안 먹히고
다음 단계가 실행되어 버리네요. (실행되면 안되고 break 되야 하는데..)

그리고 추가적으로 input[name^=price]에서 ^= <- 이 연산자가 무엇을 뜻하는지
알 수 있을까요? 종종 보이던데 도저히 무슨 뜻인지를 모르겠습니다.

감사합니다.

댓글을 작성하려면 로그인이 필요합니다.

답변을 작성하려면 로그인이 필요합니다.

로그인