광고배너

textarea 글자수 나오는 소스를 바이트수로 바꿀수 있을까요?

textarea 글자수 나오는 소스를 바이트수로 바꿀수 있을까요?

QA

textarea 글자수 나오는 소스를 바이트수로 바꿀수 있을까요?

본문

아래 소스는 textarea에 글씨를 쓰면 글자수가 나오는 소스입니다.
작동은 잘 하고 있습니다.
이것을 글자수가 아니라 바이트수로 바꿀수 있을까요?
도움 주시면 감사하겠습니다.

 


    <div class="text_box2">
 <p class="txt">글자수를 나타냅니다.<div class="count"><span>0</span>/3000</div></p>
      <textarea name="wr_content" id="wr_content"  rows="25" style="width:250px"></textarea>
                                    <script>
                                    $('.text_box2 textarea').keyup(function(){
                                      var content = $(this).val();
                                      $('.text_box2 .count span').html(content.length);
                                      if (content.length > 3000){
                                        alert("최대 3000자까지 입력 가능합니다.");
                                        $(this).val(content.substring(0, 3000));
                                        $('.text_box2 .count span').html(3000);
                                      }
                                    });
                                    </script>
            </div>

이 질문에 댓글 쓰기 :

답변 1

function getByteLength(str) {
            let byteLength = 0;
            for (let i = 0; i < str.length; i++) {
                const charCode = str.charCodeAt(i);
                if (charCode <= 0x007F) {
                    byteLength += 1; // 아스키 문자는 1바이트
                } else if (charCode <= 0x07FF) {
                    byteLength += 2; // 2바이트 문자
                } else {
                    byteLength += 3; // 3바이트 문자 (한글 등)
                }
            }
            return byteLength;
        }

        $('#wr_content').keyup(function () {
            const content = $(this).val();
            const byteLength = getByteLength(content);
            $('.text_box2 .count span').html(byteLength);
            if (byteLength > 3000) {
                alert("최대 3000바이트까지 입력 가능합니다.");
                // 입력을 3000바이트로 제한
                let trimmedContent = content;
                while (getByteLength(trimmedContent) > 3000) {
                    trimmedContent = trimmedContent.substring(0, trimmedContent.length - 1);
                }
                $(this).val(trimmedContent);
                $('.text_box2 .count span').html(getByteLength(trimmedContent));
            }
        });

답변을 작성하시기 전에 로그인 해주세요.
전체 61,225
QA 내용 검색

회원로그인

(주)에스아이알소프트 / 대표:홍석명 / (06211) 서울특별시 강남구 역삼동 707-34 한신인터밸리24 서관 1404호 / E-Mail: admin@sir.kr
사업자등록번호: 217-81-36347 / 통신판매업신고번호:2014-서울강남-02098호 / 개인정보보호책임자:김민섭(minsup@sir.kr)
© SIRSOFT