JS~字符串長度判斷,超出進行自動截取(支持中文)


今天一個小弟問我的問題,在文本框中輸入字符,如果超出指定長度,就把它截取,要求中文等於兩個字符的長度,我找一下資料,把這個功能實現了,下面是JS代碼:

<html>
<script src="http://common.cnblogs.com/script/jquery.js" type="text/javascript"></script>

<body>
    <input type="text" name="username" />
</body>
<script type="text/ecmascript">

   
    var GetLength = function (str) {
        ///<summary>獲得字符串實際長度,中文2,英文1</summary>
        ///<param name="str">要獲得長度的字符串</param>
        var realLength = 0, len = str.length, charCode = -1;
        for (var i = 0; i < len; i++) {
            charCode = str.charCodeAt(i);
            if (charCode >= 0 && charCode <= 128) realLength += 1;
            else realLength += 2;
        }
        return realLength;
    };

    //js截取字符串,中英文都能用 //如果給定的字符串大於指定長度,截取指定長度返回,否者返回源字符串。 //字符串,長度 /** * js截取字符串,中英文都能用 * @param str:需要截取的字符串 * @param len: 需要截取的長度 */ function cutstr(str, len) { var str_length = 0; var str_len = 0; str_cut = new String(); str_len = str.length; for (var i = 0; i < str_len; i++) { a = str.charAt(i); str_length++; if (escape(a).length > 4) { //中文字符的長度經編碼之后大於4 str_length++; } str_cut = str_cut.concat(a); if (str_length >= len) { str_cut = str_cut.concat("..."); return str_cut; } } //如果給定字符串小於指定長度,則返回源字符串; if (str_length < len) { return str; } }
$(function () { 
$(
"input[name=username]").bind('keyup', function () {
if (GetLength($(this).val()) > 10) {
$(
this).val(cutstr($(this).val(), 10));
return;
}
});
});
</script>
</html>

效果如圖:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM