js计算字符串长度超出部分自动截取(支持中文)

发布时间:2020-09-17编辑:脚本学堂
用js计算字符串长度,当超出指定长度后会自动截取,中文等于两个字符的长度,js截取字符串,中英文都能用。

文本框中输入字符,如果超出指定长度,则自动截取,要求中文等于两个字符的长度。

代码:
 

复制代码 代码示例:

<html>
<script src="/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计算<a href=http://www.jb200.com/zt/zifucuanchangdu/ target=_blank class=infotextkey>字符串长度</a>自动截取


字符串常用操作:字符串反转字符串替换,如何实现字符串去除重复 ,各种字符串查找方法,字符串比较字符串转换方法,字符串截取字符串分割 ,以及如何求字符串长度 等。