中文与英文字符长度判断

jellday 2009-03-23 06:13:20

String.prototype.trim= function(){
// 用正则表达式将前后空格
// 用空字符串替代。
return this.replace(/(^\s*)|(\s*$)/g, "");
}
function chklen(obj,len)
{
obj.value=obj.value.trim();//去除头尾空格
if (obj.value.length>len)
{
alert("抱歉,长度不能大于"+len+"个字符(一个中文等于两个字符)");
obj.focus();
return false;
}
}

以上只能判断非中文的,
请问如何使中文字判断为2个字符呢?

看到有人说“可以使用 "StringName".getBytes().length 这样不管是中文还是英文都被转化为字节,这样如果是中文就为2 bytes 英文就为 1 byte ,输出的就是总的长度了”

可是我用obj.value.getBytes().length显示不支持此方法/属性亚
...全文
127 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
luojihaidao 2009-03-24
  • 打赏
  • 举报
回复
学习!
licip 2009-03-24
  • 打赏
  • 举报
回复
楼上的真厉害,太对了.
2009-03-23
  • 打赏
  • 举报
回复


String.prototype.lenX = function(){
return this.replace(/[^\x00-\xff]/g,"**").length;
}

String.prototype.trim= function(){
// 用正则表达式将前后空格
// 用空字符串替代。
return this.replace(/(^\s*)|(\s*$)/g, "");
}
function chklen(obj,len)
{
obj.value=obj.value.trim();//去除头尾空格
if (obj.value.lenX() > len)
{
alert("抱歉,长度不能大于"+len+"个字符(一个中文等于两个字符)");
obj.focus();
return false;
}
}


<> 一些背景知识: 1. 一个汉字在c\c++的存储, 使用2个字节(char)存储; 2. 汉字存储的第一个char, 其值一定大于'~'(0111 1110=126),否则将导致识别歧义; 此处, 使用"单ASCII字符"来表示非 单ASCII字符判断, 可以根据以下规则(主要R3, R4); : 一个字符串的长度==1,那肯定是一个ASCII字符; : 一个字符串的长度==2,且第1个ASCII字符的编码小于'~'; 那肯定是2个单ASCII字符; -- (PS: "") : 一个字符串的长度==3,且中间的ASCII字符的编码小于'~'; 那第3个肯定是单ASCII字符; (前2个是否构成1个汉字不能确定) : (基于R3)如果第pos个位置的ASCII字符编码小于'~', 那从下标pos,pos+1处拆分字符串 (下标pos归前串),将不会导致乱码; A 或者 B 的选择,需要知道以下信息: (1). 从 cut_base_pos 开始到 pos_B 结束的这段字符串内, 最后一个单ASCII字符的结束下标 p 在此基础上, 若使用: y -- 表示单ASCII字符(已确定的); x -- 表示可能是 单ASCII字符,也可能是 汉字的半个ASCII存储码; 那么一段长度为N的字符串,按照存储的ASCII码可以表示为一串如下的字符串(不包含[]) "x .. x][x .. x y x .. x][x .. x", 其中 s,e表示当前正在分析的一段子串(0<=s长度cut_size) ^ ^ ^ ^ ^ 0 s p e N 在 【s, e】 之间, 查找结束下标p 的思路: 从e开始向s查找, 找到 第一个y 后 break; 记录下标p, 则从位置p开始, 是一个正确的分割(cut); 但此分割并不是一个最好的分割. 可以在 位置p上, 再加上 2K 个长度, 使 p+2K 与 pos_B 最接近即可. 可以认为从2K个长度的内容是K个汉字(实际上并不一定..), 但并不影响这个最佳分割的正确性! :)

87,910

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧