메뉴 건너뛰기

조회 수 2961 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부

▶▷ 알아두면 좋은 것들

조건문, 조건문에서의 and와 or, alert 메소드

 

 회원가입 폼을 만들고 나서 submit을 통한 자료 전송시에, 모든 폼이나 혹은 일부에 필수로 데이터가 입력되어야 할때,

사용가능한 유효성 검사 방법입니다. 그렇게 어려운 방법은 아니니 한번 보시고 이해 하시면 될듯 합니다 ^^.

 

 이번에는 두가지 소스를 확인하면서 내용을 설명토록 할게요.

첫번째단순히 모든 폼에 값이 입력되었는지만 확인하는 소스구요.

두번째모든 폼에 값이 입력되었는지 확인하고, 그렇지 않은 폼에 이동을해서 바로 수정이 가능하도록 하겠습니다.

 


첫번째 소스(Source)

소스다운  Doit.html

 

<HTML>
<HEAD>
<TITLE>자바스크립트를 활용한 유효성 검사1</TITLE>
</HEAD>
<SCRIPT language="javaScript">

 function check_onclick(){
    theForm=document.frm1;  
1.  if(theForm.input1.value=="" || theForm.input2.value=="" || theForm.input3.value=="" ){
        alert("필수 입력란이 비었습니다. 확인해 주세요.");
    }else{
       alert("필수 입력란을 모두 입력하셨습니다.");
    }
 }

</SCRIPT>
<BODY>
<FORM name=frm1>
     필수 입력란1 : <input type=text name=input1 size=10> <br>
     필수 입력란2 : <input type=text name=input2 size=10> <br>
     필수 입력란3 : <input type=text name=input3 size=10> <br>
     보통 입력란4 : <input type=text name=input4 size=10>(생략가능) <br>
     <input type=button value="check" onclick="check_onclick()">
</FORM>
</BODY>

</HTML>

 


소스설명

1. 필수 입력란 값 확인
if(theForm.input1.value=="" || theForm.input2.value=="" || theForm.input3.value=="" )
- if 조건문에서 theForm-여기서는 <BODY>태그내에 있는 'frm1'의 이름을 가진 폼을 의미합니다.-의 각 하위 요소인 각 텍스트 입력란의 값이 현재 비어있을때, 널(null) 즉, 화면상에서는 "" 일때 조건문이 참이 되도록 하여서 메시지를 출력 하도록 하였구요, 필수로 들어가야 할 입력란을 동일한 방법으로 나열하되 OR조건으로 나열했습니다. 그래야 나열된 조건들 중에 하나라도 값이 비어있는 것이 있으면, 바로 해당 메시지를 출력하죠.
 
 

 
결과화면
 
 

 
 
 
 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

무언가 아쉽지 않으세요?

어디가 비었는지 웹페이지가 알고,

입력이 가능하도록 그곳으로 커서를 위치하게 하면 좋겠죠?

그래서 다음 소스를 준비했습니다.


 두번째 소스(Source)

 소스다운   Doit.html

<HTML>
<HEAD>
<TITLE>자바스크립트를 활용한 유효성 검사2</TITLE>
</HEAD>
<SCRIPT language="javaScript">

 function check_onclick(){
      theForm=document.frm1;
1.    if(theForm.input1.value=="" || theForm.input2.value=="" || theForm.input3.value=="" ){
           if(theForm.input1.value==""){
                alert("필수 입력란1이 비어있습니다. 확인해주세요.")
                theForm.input1.focus();
           }else if(theForm.input2.value==""){
                alert("필수 입력란2이 비어있습니다. 확인해주세요.")
                theForm.input2.focus();
           }else{
                alert("필수 입력란3이 비어있습니다. 확인해주세요.")
                theForm.input3.focus();
           }
      }
      else{
           alert("필수 입력란을 모두 입력하셨습니다.");
      }
 }

</SCRIPT>
<BODY>
<FORM name=frm1>
     필수 입력란1 : <input type=text name=input1 size=10> <br>
     필수 입력란2 : <input type=text name=input2 size=10> <br>
     필수 입력란3 : <input type=text name=input3 size=10> <br>
     보통 입력란4 : <input type=text name=input4 size=10>(생략가능) <br>
     <input type=button value="check" onclick="check_onclick()">
</FORM>

</BODY>
</HTML>

 


소스설명

1. 필수 입력란의 재검사와 포커싱

if(theForm.input1.value=="" || theForm.input2.value=="" || theForm.input3.value=="" ){
    if(theForm.input1.value==""){
         alert("필수 입력란1이 비어있습니다. 확인해주세요.")
         theForm.input1.focus();
    }else if(theForm.input2.value==""){
         alert("필수 입력란2이 비어있습니다. 확인해주세요.")
         theForm.input2.focus();
    }else{
         alert("필수 입력란3이 비어있습니다. 확인해주세요.")
    theForm.input3.focus();
    }
}

- if문입니다. 맨 위에 있는 조건문은 첫번째 소스의 조건문과 동일하구요,

다른 점은 각 입력란 마다 다시 유효성 검사를 했다는 겁니다. 그럼 맨 위의 조건은 필요없지 않나?라는 질문이 있을수도 있는데요, 이렇게 함으로써 이벤트가 일어났을때 좀 덜 코드를 읽도록 하기 위해서 입니다. 아무튼 다시 돌아와서,

 

 각 란이 비어있으면, 메시지를 각각 띄우고, focus() 메소드를 통해서 비어있는 칸으로 이동하게 했습니다.

focus()에 대한 자세한 내용은 http://runtoyourdream.tistory.com/202 을 확인해주시면 되겠습니다.

 


결과화면

 

 

 이상 글을 마치겠습니다. 다음번에는 입력란에 정해진 타입의 값만 들어가보도록 할게요 ^^

 

 


List of Articles
번호 제목 날짜 조회 수
98 선택(CheckBox) 된 Row 삭제 - 화면에서 추가된 Row 2015.04.27 5863
97 선택된 데이터 부모창에 넘기기 (iframe ☞ 부모창) 2015.04.27 3399
96 2단계 트리메뉴 마우스오버(mouseover), 온포커스(onfocus) 구현 2015.04.06 3816
95 jquery 메뉴 - 아래로 한번에 전체가 펼처짐 file 2015.04.06 5649
94 자바스크립트 이벤트 목록입니다. ( javascript event ) 2015.04.06 2975
93 '레이블', 반복문을 제어하자! file 2015.02.03 3060
92 'Array', 배열 및 다차원 배열 선언에 대해 알아보자! 2015.02.03 5879
91 배열의 리터럴 선언, 또다른 배열 선언 방법! 2015.02.03 3368
90 '문자 ↔ 숫자', 타입을 바꿔보자! 2015.02.03 3437
89 드롭다운 메뉴를 만들어보자! -1탄 file 2015.02.03 4039
88 'onmouseover', 마우스 오버 효과 - 글씨 바꾸기! file 2015.02.03 4918
87 'setInterval', 타이머를 사용하자! ==setTimeout 2015.02.03 3232
86 'blur', 이미지 클릭시 테두리를 없애자! file 2015.02.03 3682
85 'setTimeout', 타이머를 사용하자! file 2015.02.03 3569
84 'opener', 부모창과 자식창의 텍스트를 교환하자! file 2015.02.03 3955
83 'open', 새창을 열어보자! file 2015.02.03 3422
82 'checkbox', 체크박스 모두체크 그리고 모두해제! file 2015.02.03 3852
81 'button', 클릭한 횟수 알아내기! file 2015.02.03 4677
» 유효성 검사, 모든 폼에 값이 입력되도록 해보자! file 2015.02.03 2961
79 'focus', 엔터 누르고 이동하자! file 2015.02.03 5418
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved