js处理包含中文的字符串实例
场景:
js中String类型自带的属性length获取的是字符串的字符数目,但是前端经常会需要限制字符串的显示长度,一个中文字符又大概占两个英文小写字符的显示位置,所以中英文混合的情况下用length值来判断显示长度往往并不正确。
常规的解决办法是遍历字符串,中文字符计长度2,非中文字符计长度1,通过新计算出来长度总和来限制字符串的显示长度。看代码↓↓↓
varTools={ //是否包含中文 hasZh:function(str){ for(vari=0;i255)//如果是汉字,则字符串长度加2 returntrue; returnfalse; } }, //重新计算长度,中文+2,英文+1 getlen:function(str){ varstrlen=0; for(vari=0;i 255)//如果是汉字,则字符串长度加2 strlen+=2; else strlen++; } returnstrlen; }, //限制长度 limitlen:function(str,len){ varresult=""; varstrlen=0; for(vari=0;i 255)//如果是汉字,则字符串长度加2 strlen+=2; else strlen++; result+=str.substr(i,1); if(strlen>=len){ break; } } returnresult; } }
这种方法的原理是根据中英文的unicode编码范围不同来判断的,中文占2个字节,英文占1个字节,所以中文的unicode编码值肯定大于2^8-1=255。
上述方法可以更严谨一点:就是考虑unicode编码范围,具体的范围可以戳UnicodeTable
PS:汉字的unicode编码范围16进制为4E00-9FA5,10进制则为:19968-40869,即判断中文的准确表达式为:
str.charCodeAt(i)>=19968&&str.charCodeAt(i)<=40869
插一句不太严谨的话,代码不用限制太严谨的范围,毕竟你不知道用户(测试)会输哪些奇怪的东西。
以上这篇js处理包含中文的字符串实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。