메뉴 건너뛰기

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

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

아직도 자바스크립트에 관해서는 많이 서툰 필자가 그동안 품어왔던 자바 스크립트에 대한 의문중 하나를 풀게 되었다.(기초부터 차근차근 배웠다면 풀고 말고도 없었을꺼 같지만.ㅡ.ㅡ)
"왜 자바에는 replace가 한번만 치환을 할까?" 하는 의문점이 바로 그것인데..(왜 자바스크립트에는 trim함수가 없을까는.. \s 때문일려나?)
그 이유는 자바스크립트가 다른 언어에서 처럼 정규식 치환함수와, 일반적인 치환함수가 따로 있는 것이 아니라 replace 함수가 정규식도 취급하고 있기 때문에 였던것이다.
그리고 그와 관련해서 필자가 한번에 모두 바꾸어주는 기능으로 하려고 했던것까지 같이 소개를 해보겠다. 아래 소스를 보자.

<meta http-equiv="content-type" content="text/html; charset=utf-8">
<script type="text/javascript" src="http://code.jquery.com/jquery-latest.js"></script>
<script type="text/javascript">
$( function(){
	$( 'input' ).on("blur keyup", function() {
		$(this).val( $(this).val().replace( /[ㄱ-ㅎ|ㅏ-ㅣ|가-힣]/g, '' ) );
	});
})
</script>

<input type="text">
 

해당 input box에 한글이 입력되면 onBlur나 onKeyup시에 해당 한글을 공백으로 치환하여 한글을 입력 못하게 해주는 소스이다.

뭐, 문제점도 꾀 있는 소스라서, 사용자가 쓰기 편하게 해주려면, onBlur시에 한글이 있으면, 메세지창을 띄워주고 한글을 치환해주는 방식을 사용해야 하겠지만, 좀더 많은 기능을 보여주기 위해서 위처럼 소스를 구성해놓았다.

위에서 언급했던 모두 치환을 당담하는것은, 정규식의 g 부분이다. 해당위치에 오는 문자에 따라서
g : 문자열 내의 모든 패턴 체크
i : 대소문자를 구별하지 않음
m : 여러줄에 걸쳐서 체크
와 같이 된다.

참고로 한글 이외의 키보드에 있는 영문, 숫자, 특수문자, space는 쓰고 싶다면,

 
/[^A-Za-z0-9_\`\~\!\@\#\$\%\^\&\*\(\)\-\=\+\\\{\}\[\]\'\"\;\:\<\,\>\.\?\/\s]/gm;

와 같은 정규식을 쓰면 된다.

응용이라던가 하는것은 알아서 해보기 바란다.


List of Articles
번호 제목 날짜 조회 수
179 jquery selector / jquery 선택자 / 자주 사용하는 jquery selector 선택자 / selecter 2016.09.09 8149
178 ajax 아작스 통신 2016.09.09 8046
177 강제 click 이벤트 발생 2016.09.09 7734
176 벨리데이션 체크 / validator / 자동 입력 제한 2016.09.09 7142
175 각종 다이어그램 플러그인 / 차트 / 관계 플러그인 2016.09.09 9489
174 jqGrid / custom pager / custom paging / 그리드 / 페이징 file 2016.09.09 12522
173 [jQuery Plugin] FCKeditor 2.6.5 사용법 2016.09.11 7179
172 jquery 이용한 이미지 변환 2016.09.11 7360
171 jquery function 생성 2016.09.11 6963
170 [jQuery] 이용 아이디 중복체크 실시간 2016.09.11 8876
169 jQuery Quick API file 2016.09.13 6934
168 이미지 클릭시 확대하기 file 2016.09.21 12648
167 Get방식 파라미터 전송 & 탭 메뉴 선택 2016.09.21 8566
166 간단한 세로 메뉴 file 2016.09.21 7306
165 Input TYPE=“File” 을 히든으로 하고 외부 버튼을 눌러서 파일을 선택 2016.09.21 6801
164 document.getElementById() 처럼 DOM 객체 얻기 2016.09.21 6810
163 select box 값 변경, 목록 변경 2016.09.21 9065
162 슬라이드 쇼 file 2016.09.21 6611
161 jQuery Cookie 2016.09.21 6864
160 체크박스 또는 라디오 버튼의 체크여부 변경하기 2016.09.21 6667
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved