취미 :     
- output.html -...","url":"https://sir.kr/boards/program/19667","author":{"@type":"Person","name":"돌아온깡통","url":"https://sir.kr/profile/9bcfd031-59e9-4636-8833-032608c30714"},"interactionStatistic":[{"@type":"InteractionCounter","interactionType":{"@type":"LikeAction"},"userInteractionCount":0},{"@type":"InteractionCounter","interactionType":{"@type":"CommentAction"},"userInteractionCount":0}],"datePublished":"2014-08-26T17:55:44+09:00","dateModified":"2014-08-26T17:55:44+09:00"}

자바스크립트(3)

· 11년 전 · 2507

- input.html -


<script language = "javascript">

  function output(form) {

    var string = form.hobby.value;

    if(!string) {

      alert("취미를 입력하세요!");

      form.hobby.focus();

      return;

    } else {

      form.submit();

    }
  }

</script>

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

  취미 :   <input type = "text" name = "hobby">

  <input type = "button" value = "확인" onclick = "output(this.form)">

</form>


- output.html -


<?
echo("당신의 취미 : $hobby");
?>

위 예제는 앞 강좌의 마지막 예제에 몇 가지가 추가되고 수정된 부분이 있습니다.

먼저, 앞 강좌에서는 output() 함수 내에서 hobby 이름을 가진 텍스트 박스의 객체를 표현할 때 document.input_form.hobby.value 라고 써줬습니다.

그런데, 위 예제에서는 조금 단축해서, form.hobby.value 라고 쓰여진 것을 볼 수 있습니다.

왜냐하면, 위 예제의 <form> .. </form> 태그 안에 기술된 button 객체의 onclick 이벤트의 호출 함수 즉, output() 함수의 인자로 this.form 이라는 것을 써 주었으며, 그 호출 함수의 형식과 일치하게 자바스크립트의 코드에 선언된 output() 함수 역시 form 이라는 인자를 가지도록 써 주었기 때문입니다.

즉, 버튼을 눌렀을 때 그 버튼(button) 객체를 포함하고 있는 상위 객체 즉, input_form 객체명을 this.form 이라는 인자에 실어서 실제로 선언된 output() 함수의 form 인자로 전달하기 때문에, 그 output() 함수 안에서 input_form 객체에 포함된 button 객체나 hobby(텍스트 박스) 객체를 표현할 때, 굳이 그 상위 객체의 실제 이름을 명시해 줄 필요가 없는 것입니다.

(이해하시기가 좀 어렵나요?..^^;)

암튼, 위 예제에서 form.hobby.value 라는 코드는 input_form.hobby.value 와 동일한 의미를 가집니다.

다음으로, form.hobby.focus(); 코드가 보이죠. 이 focus() 라는 새로운 메소드(method)는 해당 객체에 커서를 위치시키는 역할을 합니다.

따라서, 위 예제에서 form.hobby.focus(); 코드는 hobby 라는 이름을 가진 텍스트 박스로 커서를 위치시키라는 의미가 되겠죠.

다음, return; 구문이 보이죠. 이 return 명령어는 전에 함수(function) 부분을 설명하는 강좌에서 잠깐 말씀드린 것처럼, 함수의 반환값을 되돌려 주거나, 함수의 실행을 중지시킬 때 사용되는 명령어입니다.

다음으로 form.submit(); 이라는 코드도 보이죠. 이 submit() 메소드는 해당 form 객체안에 있는 하위 객체의 입력 혹은 선택값들을 전송하라는 의미입니다.

여기에서는, hobby 이름을 가진 텍스트 박스의 입력값을 전송하라는 의미가 되겠죠.

그리고, form.submit(); 에 의해 전송될 값들은 <form> 태그안의 action = "..." 에 명시된 웹 페이지로 전송되게 됩니다.

따라서, 위 예제에서는 hobby 텍스트 박스에 입력한 문자열이 같은 디렉토리에 존재하는 output.html 파일로 전송되게 됩니다.

그 결과, 텍스트 박스 객체명에 해당되는 hobby 가 output.html 파일 내에서는 $hobby 라는 변수가 되며, echo() 명령어에 의해 $hobby 변수값 즉, 사용자가 입력한 문자열이 출력되게 됩니다.

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

프로그램

+
제목 글쓴이 날짜 조회
11년 전 조회 2,784
11년 전 조회 2,452
11년 전 조회 2,364
11년 전 조회 2,392
11년 전 조회 3,256
11년 전 조회 2,297
11년 전 조회 2,373
11년 전 조회 4,017
11년 전 조회 3,696
11년 전 조회 2,572
11년 전 조회 3,108
11년 전 조회 2,622
11년 전 조회 2,559
11년 전 조회 2,737
11년 전 조회 3,301
11년 전 조회 2,294
11년 전 조회 3,364
11년 전 조회 3,611
11년 전 조회 2,284
11년 전 조회 2,396
11년 전 조회 2,130
11년 전 조회 3,079
11년 전 조회 2,986
11년 전 조회 2,446
11년 전 조회 2,336
11년 전 조회 2,087
11년 전 조회 2,519
11년 전 조회 2,927
11년 전 조회 1,985
11년 전 조회 2,176
11년 전 조회 2,313
11년 전 조회 2,308
11년 전 조회 2,513
11년 전 조회 4,031
11년 전 조회 3,720
11년 전 조회 3,155
11년 전 조회 2,839
11년 전 조회 2,763
11년 전 조회 3,764
11년 전 조회 2,991
11년 전 조회 4,188
11년 전 조회 5,022
11년 전 조회 5,161
11년 전 조회 5,210
11년 전 조회 5,351
11년 전 조회 3,824
11년 전 조회 1.9만
11년 전 조회 2,785
11년 전 조회 2,513
11년 전 조회 2,508
11년 전 조회 2,285
11년 전 조회 2,445
11년 전 조회 2,297
11년 전 조회 2,071
11년 전 조회 2,512
11년 전 조회 2,212
11년 전 조회 2,154
11년 전 조회 2,424
11년 전 조회 2,331
11년 전 조회 2,129
11년 전 조회 2,286
11년 전 조회 2,293
11년 전 조회 2,289
11년 전 조회 2,409
11년 전 조회 1,999
11년 전 조회 2,080
11년 전 조회 2,245
11년 전 조회 2,110
11년 전 조회 2,161
11년 전 조회 2,083
11년 전 조회 2,030
11년 전 조회 2,114
11년 전 조회 2,752
11년 전 조회 2,058
11년 전 조회 2,377
11년 전 조회 2,255
11년 전 조회 2,018
11년 전 조회 2,036
11년 전 조회 2,130
11년 전 조회 2,077
11년 전 조회 2,668
11년 전 조회 5,560
11년 전 조회 2,624
11년 전 조회 2,350
11년 전 조회 2,787
11년 전 조회 8,977
11년 전 조회 2,538
11년 전 조회 3,752
11년 전 조회 2,557
11년 전 조회 2,506
11년 전 조회 2,804
11년 전 조회 2,295
11년 전 조회 2,284
11년 전 조회 2,279
11년 전 조회 2,326
11년 전 조회 2,954
11년 전 조회 2,348
11년 전 조회 2,605
11년 전 조회 2,396
11년 전 조회 6,097