메뉴 건너뛰기

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

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

input text 형식에서 문자를 입력받고 DB에 넣을때 사이즈가 커서 오류가 발생하는 경우가 발생합니다.


아래 예제는 앞에서 byte 수를 확인하고 정해진 byte 길이로 자른후 나머지 값을 입력하는 방식입니다.


처음에는 keyup 으로 처리 하였으나 blur로 변경하였습니다.


과거에 작성했던것의 업그레이드 버전입니다. (과거버전: http://huskdoll.tistory.com/386)


예제는 다음과 같습니다. 예제 밑에 inputbox에서 실제로 확인해보세요. (입력창에서 포커스가 벗어나면 실행됩니다.)


<!doctype html>
<html lang="kr">
<head>
  <meta charset="utf-8">
  <title>demo</title>
  <script src="https://code.jquery.com/jquery-1.10.2.js"></script>
  <script>
    $(document).ready( function() {
        //글자 byte 수 제한
        $('.byteLimit').blur(function(){
                         
            var thisObject = $(this);
             
            var limit = thisObject.attr("limitbyte"); //제한byte를 가져온다.
            var str = thisObject.val();
            var strLength = 0;
            var strTitle = "";
            var strPiece = "";
            var check = false;
                     
            for (i = 0; i < str.length; i++){
                var code = str.charCodeAt(i);
                var ch = str.substr(i,1).toUpperCase();
                //체크 하는 문자를 저장
                strPiece = str.substr(i,1)
                 
                code = parseInt(code);
                 
                if ((ch < "0" || ch > "9") && (ch < "A" || ch > "Z") && ((code > 255) || (code < 0))){
                    strLength = strLength + 3; //UTF-8 3byte 로 계산
                }else{
                    strLength = strLength + 1;
                }
                 
                if(strLength>limit){ //제한 길이 확인
                    check = true;
                    break;
                }else{
                    strTitle = strTitle+strPiece; //제한길이 보다 작으면 자른 문자를 붙여준다.
                }
                 
            }
             
            if(check){
                alert(limit+"byte 초과된 문자는 잘려서 입력 됩니다.");
            }
             
            thisObject.val(strTitle);
             
        });
    });
     
  </script>
</head>
<body>
    10byte 제한: <input type="text" class="byteLimit" limitbyte="10"><br><br><!-- limitbyte로 제한byte를 셋팅-->
    20byte 제한: <input type="text" class="byteLimit" limitbyte="20"><br><br>
    30byte 제한: <input type="text" class="byteLimit" limitbyte="30">
</body>
</html>

10byte 제한:

20byte 제한:

30byte 제한:


List of Articles
번호 제목 날짜 조회 수
119 jQuery를 이용한 스크롤 따라니는 배너를 쉽게 맨들기(scroll follow) file 2019.01.10 1093
118 jQuery Plugin : Slider file 2019.01.10 1113
117 jQuery 기초 (attr()로 두가지 동시에 접근 / 변경) 2019.01.16 1119
116 attr() - style의 특정 속성만 바꾸기 2021.03.26 1125
115 [jQuery] 라디오(radio) 버튼, 체크박스(checkbox) 선택/해제 하는 방법 2019.03.05 1129
114 jQuery 기초 (style.css <link> 로 추가하기 / 버튼 클릭시 데이터 삽입) file 2019.01.16 1181
113 jQuery로 테이블 tr 동적으로 추가,삭제 하기 v2 2019.01.10 1211
112 popModal jQuery Plugin Examples / 무료 jQuery 팝업 플러그인 file 2019.01.16 1235
111 jQuery 기초 (focus, blur, toggle / mouseenter, mouseleave, mousedown, mouseup, hover) 2019.01.16 1268
110 터치 디바이스 분기처리 2018.11.07 1278
109 Hide pager if bxslider has only 1 slide 2018.11.07 1296
108 getElementsByClassName 을 IE8 이하에서 동작하게 하는 코드 2018.11.07 1297
107 Magnific popup conflict with "jquery.nicescroll" file 2018.11.07 1315
106 jQuery 기초 (jQuery 달력 (datepicker)) file 2019.01.16 1321
105 jQuery 로 탭메뉴 보였다 안보였다 맹글기 2019.01.10 1329
104 jQuery 기초 (Postcodify - 도로명주소 우편번호 검색 프로그램 (코딩 예제) (HTML) / POP UP 버젼) file 2019.01.16 1349
103 selectbox multiple 선택한 값들 submit 해서 받기 2021.03.26 1362
102 3D Perspective Carousel with jQuery and CSS3 - CSSSlider 2018.11.07 1388
101 비활성화 된 라디오버튼 클릭 시 경고창 생성 2018.11.07 1396
100 iframe height auto resize 2018.11.07 1401
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved