자바스크립트(4)

· 11년 전 · 1322

<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,265
11년 전 조회 1,617
11년 전 조회 1,240
11년 전 조회 1,188
11년 전 조회 1,220
11년 전 조회 2,046
11년 전 조회 1,116
11년 전 조회 1,162
11년 전 조회 2,962
11년 전 조회 2,519
11년 전 조회 1,390
11년 전 조회 1,879
11년 전 조회 1,472
11년 전 조회 1,399
11년 전 조회 1,538
11년 전 조회 2,124
11년 전 조회 1,131
11년 전 조회 2,172
11년 전 조회 2,408
11년 전 조회 1,108
11년 전 조회 1,251
11년 전 조회 956
11년 전 조회 1,910
11년 전 조회 1,793
11년 전 조회 1,283
11년 전 조회 1,161
11년 전 조회 932
11년 전 조회 1,324
11년 전 조회 1,767
11년 전 조회 829
11년 전 조회 1,033
11년 전 조회 1,116
11년 전 조회 1,136
11년 전 조회 1,338
11년 전 조회 2,848
11년 전 조회 2,515
11년 전 조회 2,001
11년 전 조회 1,641
11년 전 조회 1,576
11년 전 조회 2,570
11년 전 조회 1,823
11년 전 조회 3,022
11년 전 조회 3,840
11년 전 조회 3,956
11년 전 조회 4,013
11년 전 조회 4,133
11년 전 조회 2,615
11년 전 조회 1.8만
11년 전 조회 1,581
11년 전 조회 1,323
11년 전 조회 1,262
11년 전 조회 1,088
11년 전 조회 1,235
11년 전 조회 1,066
11년 전 조회 877
11년 전 조회 1,281
11년 전 조회 1,037
11년 전 조회 935
11년 전 조회 1,271
11년 전 조회 1,163
11년 전 조회 939
11년 전 조회 1,101
11년 전 조회 1,112
11년 전 조회 1,119
11년 전 조회 1,227
11년 전 조회 846
11년 전 조회 904
11년 전 조회 1,083
11년 전 조회 941
11년 전 조회 982
11년 전 조회 928
11년 전 조회 870
11년 전 조회 942
11년 전 조회 1,559
11년 전 조회 881
11년 전 조회 1,196
11년 전 조회 1,082
11년 전 조회 835
11년 전 조회 848
11년 전 조회 945
11년 전 조회 915
11년 전 조회 1,463
11년 전 조회 4,350
11년 전 조회 1,435
11년 전 조회 1,163
11년 전 조회 1,614
11년 전 조회 7,755
11년 전 조회 1,347
11년 전 조회 2,561
11년 전 조회 1,377
11년 전 조회 1,422
11년 전 조회 1,713
11년 전 조회 1,209
11년 전 조회 1,211
11년 전 조회 1,201
11년 전 조회 1,232
11년 전 조회 1,872
11년 전 조회 1,246
11년 전 조회 1,401
11년 전 조회 1,200