您好,登錄后才能下訂單哦!
今天一個小弟問我的問題,在文本框中輸入字符,如果超出指定長度,就把它截取,要求中文等于兩個字符的長度,我找一下資料,把這個功能實現了,
下面是JS代碼:
<html> <script src="http://jb51.net/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>
效果如圖:
以上這篇JS字符串長度判斷,超出進行自動截取的實例(支持中文)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。