- Today
- Total
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
- 재능이의 돈버는 일기
- StresslessLife
- K_JIN2SM
- 소소한 일상
- My Life Style & Memory a Box
- Blog's generation
- 공감 스토리
- 취객의 프로그래밍 연구실
- Love Me
- Dream Archive
- 세상에 발자취를 남기다 by kongmingu
- hanglesoul
- 카마의 IT 초행길
- 느리게.
- 미친듯이 즐겨보자..
- Joo studio
- Gonna be insane
- 악 다 날아갔어!! 갇대밋! 왓더...
- xopowo05
- 맑은공기희망운동
- 엔지니어 독립운동
- 혁준 블로그
- Simple in Complex with Simple
- 무의식이 의식을 지배한다
드럼치는 프로그래머
[JavaScript] HTML Input Text에 숫자 입력시 자바스크립트 정규식을 이용한 자릿수 제한 본문
[JavaScript] HTML Input Text에 숫자 입력시 자바스크립트 정규식을 이용한 자릿수 제한
드럼치는한동이 2016. 7. 25. 01:17조건
1. Textbox에 숫자만 입력 받는다.
2. 입력받은 숫자는 1000 이하의 숫자만 받는다.
3. 소수점은 둘째자리까지만 받는다.
<input type="text" onkeypress="return isNumberKey(event)" />
function isNumberKey(evt) {
var charCode = (evt.which) ? evt.which : event.keyCode;
if (charCode != 46 && charCode > 31 && (charCode < 48 || charCode > 57))
return false;
// Textbox value
var _value = event.srcElement.value;
// 소수점(.)이 두번 이상 나오지 못하게
var _pattern0 = /^\d*[.]\d*$/; // 현재 value값에 소수점(.) 이 있으면 . 입력불가
if (_pattern0.test(_value)) {
if (charCode == 46) {
return false;
}
}
// 1000 이하의 숫자만 입력가능
var _pattern1 = /^\d{3}$/; // 현재 value값이 3자리 숫자이면 . 만 입력가능
if (_pattern1.test(_value)) {
if (charCode != 46) {
alert("1000 이하의 숫자만 입력가능합니다");
return false;
}
}
// 소수점 둘째자리까지만 입력가능
var _pattern2 = /^\d*[.]\d{2}$/; // 현재 value값이 소수점 둘째짜리 숫자이면 더이상 입력 불가
if (_pattern2.test(_value)) {
alert("소수점 둘째자리까지만 입력가능합니다.");
return false;
}
return true;
}
참고
원래는 아래와 같이 Input Text 의 onkeyup 이벤트 아래 함수를 호출해 처리할라 했으나,
키보드 연타시 가끔 이벤트가 먹히는 현상이 있어 위와같이 처리함.
<input type="text" onkeyup="return checkMaxNum(event)" />
function checkMaxNum(evt) {
var _pattern = /^(\d{1,3}([.]\d{0,2})?)?$/;
var _value = event.srcElement.value;
if (!_pattern.test(_value)) {
alert("1000 이하의 숫자만 입력가능하며,\n소수점 둘째자리까지만 허용됩니다.");
event.srcElement.value = event.srcElement.value.substring(0,event.srcElement.value.length - 1);
event.srcElement.focus();
}
}
'★─Programing > ☆─WebProgram' 카테고리의 다른 글
[JavaScript] 소문자 입력시 대문자로 변환 (0) | 2016.07.25 |
---|---|
[JSTL] c:set <spring:message> value값에 스프링 메시지 코드값 넣기 (1) | 2016.07.25 |
[JavaScript] 한글 및 영문 입력방지 input 만들기 (0) | 2016.07.20 |
[Ajax] jQuery Ajax 실행 시, 로딩바 구현하기 (0) | 2016.07.20 |
[jQuery] 값넣기 또는 값가져오기 (0) | 2016.07.19 |