文章正文

JS~字符串长度判断,超出进行自动截取(支持中文)

【文章】2020-04-23

简介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截取字符串,中英文都能用    
		//如果给定的字符串大于指定长度,截取指定长度返回,否者返回源字符串。      
		//字符串,长度      
		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>

打赏支持

感谢您的支持,加油!

打开微信扫码打赏,你说多少就多少

找书费时,联系客服快速查找!

扫码支持

在线客服8:30-22:30,若离线请留言!

获取教程,请联系在线客服!

扫码支持

在线客服8:30-22:30,若离线请留言!

热门阅读

找PDF电子书,太费时间?

  • 微信扫描二维码,让客服快速查找。
  • 在线客服8:30-22:00,若离线请留言!