자바스크립트(4)

· 11년 전 · 1192

<script language = "javascript">

  function output(form) {
  
    for(var i = 0; i < form.fruit.length; i++) {
      
      if(form.fruit[i].checked) {      
        
        var output = "당신이 좋아하는 과일은 " + form.fruit[i].value + "입니다.";

        alert(output);

        break;  

     }
      
    }

    if(i == form.fruit.length) {

      alert("좋아하는 과일을 선택하세요!");      

      return;
        
    }

  }  
</script>

<form name = "select_form">

  좋아하는 과일을 선택하세요.<br><br>
  
  <input type = "radio" name = "fruit" value = "오렌지">오렌지<br>
  <input type = "radio" name = "fruit" value = "포도">포도<br>
  <input type = "radio" name = "fruit" value = "사과">사과<br>
  <input type = "radio" name = "fruit" value = "토마토">토마토<br><br>  
    
  <input type = "button" value = "선택" onclick = "output(this.form)">

</form>

위 예제는 네 가지 과일 중 한 가지를 선택한 후 선택 버튼을 눌렀을 때 그 선택한 과일명을 경고 박스 형태로 출력해주는 예제입니다.

그리고, 만일 사용자가 아무 것도 선택하지 않고 버튼을 눌렀을 경우에는 "좋아하는 과일을 선택하세요!" 라는 메시지를 출력하는 기능도 가지고 있습니다.

그런데, 앞 강좌에서 텍스트 박스의 문자열 입력 여부를 체크하는 코드에 비해, 위 예제의 라디오 버튼 객체의 경우 선택했는지의 여부를 체크하는 코드가 좀 복잡한 것을 볼 수 있죠.

먼저, 위 자바스크립트 코드의 for() 구문 안에 보이는 form.fruit.length 가 의미하는 것은 fruit 이라는 이름을 가진 라디오 버튼 객체의 갯수를 의미합니다.

따라서, form.fruit.length 값은 4 가 되겠죠.

다음으로, if() 조건문 안에 form.fruit[i].checked 가 보이죠.

여기에서 단순히 fruit 이라고 하지 않고 fruit[i] 과 같은 배열 형태의 변수가 쓰였는데, 왜냐하면 라디오 버튼 객체의 특징이 객체명(name)은 모두 동일하고 단지 각각의 요소의 값만 다르기 때문입니다.

다시 말해서, 위 예제의 경우 4 개의 라디오 버튼 객체가 쓰였는데, 그 라디오 버튼 객체들 모두가 "fruit" 이라는 이름(name)을 가지고 있으며, 단지 값(value)만 서로 다른 값들("오렌지", "포도", "사과", "토마토")을 가지고 있기 때문입니다.

그래서, 그 동일한 이름을 가진 객체들 각각을 구분해주기 위해서는 배열 변수의 형태로 표현해주어야 합니다.(전에 배열 변수에 대해 설명드렸던 내용 기억나시죠.)

따라서, 위 예제의 경우 fruit[0] 은 "오렌지" 객체를 가리키고, fruit[1] 은 "포도" ... 이런 식으로 대응이 되겠죠.

그리고, form.fruit[i].checked 코드에서 checked 속성(property)은 사용자가 그 라디오 버튼을 선택했는지의 여부를 알려줍니다.

그래서, 만일 사용자가 "사과" 표시가 되어 있는 라디오 버튼을 선택하게 되면 form.fruit[2].checked 값은 true(참) 값을 가지게 되며, 나머지 라디오 버튼 객체들의 checked 속성 값은 false(거짓) 값을 가지게 됩니다.

그럼, 위 자바스크립트 예제의 for() 구문과 그 안에 사용된 if() 구문에 대한 이해가 되시죠.

다음으로, if(i == form.fruit.length) 라는 조건식이 보이죠.

위 조건식의 의미는..

만일, 위 예제에 사용된 4 개의 라디오 버튼 객체 중 4 번째인 "토마토" 를 선택하였을 경우, for 구문에 의해 i 값이 3 을 가지게 될 때 그 선택한 문자열이 화면에 출력되게 되며, 바로 break 문에 의해 for 구문을 빠져나가게 되겠죠.

즉, 라디오 버튼 객체를 선택하였을 경우 i 변수의 최종값은 from.fruit.length 인 4 값보다 작겠죠.

그런데, 사용자가 아무 것도 선택하지 않았을 경우, 위 예제의 for() 반복문에 사용된 i 변수값이 1 씩 증가하다가, 결국 form.fruit.length 값에 해당되는 4 라는 값을 가지게 됩니다.

따라서, if(i == form.fruit.length) 조건식이 만족한다는 것은 사용자가 아무 것도 선택하지 않았다는 것을 의미하게 되며, 그래서 경고 메시지를 출력하게 됩니다.

어느 정도 이해가 되시죠.

그럼, 오늘 배운 내용을 포함한 지금까지 배운 내용들을 정리하는 의미에서, 두 값을 입력받은 후 각각의 연산자를 선택하여 계산을 수행하는 예제를 보겠습니다.

- input.html -


<script language = "javascript">

  function output(form) {
  
   if(!form.value_1.value) {
      alert("첫 번째 값을 입력하세요!");
      form.value_1.focus();
      return;
    }    

   if(!form.value_2.value) {
      alert("두 번째 값을 입력하세요!");
      form.value_2.focus();
      return;
    }    

    for(var i = 0; i < form.operator.length; i++) {      

      if(form.operator[i].checked) {      
        break;  
     }

    }

    if(i == form.operator.length) {
      alert("수행할 연산자를 선택하세요!");      
      return;        
    }

    form.submit();
    
  }  
</script>

<form name = "select_form" method = "post" action = "./output.html">

  두 값을 입력하세요!<br><br>

  <input type = "text" name = "value_1" size = "4">
  <input type = "text" name = "value_2" size = "4"><br><br>

  수행할 연산자를 선택하세요!<br><br>
  
  <input type = "radio" name = "operator" value = "add">덧셈<br>
  <input type = "radio" name = "operator" value = "minus">뺄셈<br>
  <input type = "radio" name = "operator" value = "multiply">곱셈<br>
  <input type = "radio" name = "operator" value = "divide">나눗셈<br><br>  
    
  <input type = "button" value = "계산" onclick = "output(this.form)">

</form>


- output.html -


<?
switch ($operator) {
  case ("add") :
    $result = $value_1 + $value_2;
    echo("$value_1 + $value_2 = $result");
    break;

  case ("minus") :
    $result = $value_1 - $value_2;
    echo("$value_1 - $value_2 = $result");
    break;

  case ("multiply") :
    $result = $value_1 * $value_2;
    echo("$value_1 * $value_2 = $result");
    break;

  case ("divide") :
    $result = $value_1 / $value_2;
    echo("$value_1 / $value_2 = $result");
}
?>

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

프로그램

태그 필터 (최대 3개) 전체 개발자 소스 기타 mysql 팁자료실 javascript php linux flash 정규표현식 jquery node.js mobile 웹서버 os 프로그램 강좌 썸네일 이미지관련 도로명주소 그누보드5 기획자 견적서 계약서 기획서 마케팅 제안서 seo 통계 서식 통계자료 퍼블리셔 html css 반응형 웹접근성 퍼블리싱 표준화 반응형웹 홈페이지기초 부트스트랩 angularjs 포럼 스크린리더 센스리더 개발자톡 개발자팁 퍼블리셔톡 퍼블리셔팁 기획자톡 기획자팁 프로그램강좌 퍼블리싱강좌
+
제목 글쓴이 날짜 조회
11년 전 조회 1,144
11년 전 조회 1,488
11년 전 조회 1,126
11년 전 조회 1,044
11년 전 조회 1,091
11년 전 조회 1,932
11년 전 조회 993
11년 전 조회 1,048
11년 전 조회 2,829
11년 전 조회 2,380
11년 전 조회 1,244
11년 전 조회 1,740
11년 전 조회 1,348
11년 전 조회 1,280
11년 전 조회 1,403
11년 전 조회 2,010
11년 전 조회 1,031
11년 전 조회 2,046
11년 전 조회 2,270
11년 전 조회 967
11년 전 조회 1,128
11년 전 조회 831
11년 전 조회 1,791
11년 전 조회 1,664
11년 전 조회 1,147
11년 전 조회 1,030
11년 전 조회 803
11년 전 조회 1,193
11년 전 조회 1,630
11년 전 조회 696
11년 전 조회 896
11년 전 조회 979
11년 전 조회 995
11년 전 조회 1,204
11년 전 조회 2,723
11년 전 조회 2,371
11년 전 조회 1,915
11년 전 조회 1,505
11년 전 조회 1,455
11년 전 조회 2,422
11년 전 조회 1,696
11년 전 조회 2,894
11년 전 조회 3,710
11년 전 조회 3,830
11년 전 조회 3,888
11년 전 조회 4,002
11년 전 조회 2,466
11년 전 조회 1.8만
11년 전 조회 1,437
11년 전 조회 1,193
11년 전 조회 1,136
11년 전 조회 969
11년 전 조회 1,110
11년 전 조회 932
11년 전 조회 760
11년 전 조회 1,158
11년 전 조회 898
11년 전 조회 814
11년 전 조회 1,146
11년 전 조회 1,022
11년 전 조회 812
11년 전 조회 944
11년 전 조회 984
11년 전 조회 991
11년 전 조회 1,083
11년 전 조회 722
11년 전 조회 787
11년 전 조회 968
11년 전 조회 816
11년 전 조회 840
11년 전 조회 815
11년 전 조회 735
11년 전 조회 809
11년 전 조회 1,414
11년 전 조회 749
11년 전 조회 1,057
11년 전 조회 941
11년 전 조회 700
11년 전 조회 716
11년 전 조회 789
11년 전 조회 805
11년 전 조회 1,338
11년 전 조회 4,216
11년 전 조회 1,287
11년 전 조회 1,021
11년 전 조회 1,492
11년 전 조회 7,614
11년 전 조회 1,201
11년 전 조회 2,423
11년 전 조회 1,236
11년 전 조회 1,281
11년 전 조회 1,568
11년 전 조회 1,073
11년 전 조회 1,073
11년 전 조회 1,073
11년 전 조회 1,094
11년 전 조회 1,749
11년 전 조회 1,124
11년 전 조회 1,270
11년 전 조회 1,062
🐛 버그신고