메뉴 건너뛰기

조회 수 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
번호 제목 날짜 조회 수
59 [jQuery] split, join 으로 공백제거 하기 2018.09.06 2146
58 [jQuery] 라디오(radio) 버튼, 체크박스(checkbox) 선택/해제 하는 방법 2019.03.05 1129
57 [jQuery] 셀렉트박스에서 특정 옵션 선택시 레이어 나타내기 2018.09.27 2553
56 [jQuery] 이용 아이디 중복체크 실시간 2016.09.11 8876
55 [jQuery] 확인 창(confirm), 페이지 이동(location.replace) 2018.09.06 2652
54 각종 다이어그램 플러그인 / 차트 / 관계 플러그인 2016.09.09 9489
53 간단한 마우스 포인터 따라 다니기 2021.03.26 594
52 간단한 세로 메뉴 file 2016.09.21 7306
51 간단한 스크롤 따라 움직이는 메뉴 만들기 2021.03.26 727
50 강제 click 이벤트 발생 2016.09.09 7734
49 검토하기: jQuery를 이용하여 form 처리하기 2017.03.02 7513
48 금액단위 제거 표기 2016.12.22 6217
47 기본 동작 막기 2021.03.25 284
46 날짜 검색 범위 정하기 (jquery) file 2016.11.17 7320
45 다른 프레임에 있는 객채 참조하는 방법 2016.09.21 6471
44 다중 select 2021.03.31 316
43 동적으로 콤보(select)의 항목(option) 생성하기 2016.09.21 14377
42 드래그 & 드랍 구현 - on()[이벤트리스너] file 2018.09.06 2896
41 디자인 셀렉트 박스 & CSS 2016.12.22 6347
40 따욤표 중복으로 출력하기 2018.09.28 1884
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved