littleQ

终于明白曾经他们失落的目光,当年的你们是否一样;间有懈怠或有颓放,难知多久方能补上;今起,不再彷徨!

  BlogJava :: 首页 :: 联系 :: 聚合  :: 管理
  33 Posts :: 0 Stories :: 60 Comments :: 0 Trackbacks
在js里,一个中文字符的length是1,但是提交到数据库中,就占了两个字节,验证误差,直接抛异常。
如果一个字段在oracle里是varchar2(64),如果录入33个汉字,用length的话是33,但是到oracle里就是66个字节了,插入操作肯定出错。
我们可以定义一个新的函数getBytes()取得字符串的字节数,在java里,这个函数是标准函数。
String.prototype.getBytes = function() {    
    
var cArr = this.match(/[^\x00-\xff]/ig);    
    
return this.length + (cArr == null ? 0 : cArr.length);    
}


function paramCheck(cur){
    
if(cur.value.getBytes() > 64){
    alert(
"字符超过64个字符");
    
return false;
    }

    
return true;
}
getBytes用正则表达式来判断字符串中包含汉字的个数,包含的汉字都放到数组cArr中,这样cArr的长度就是汉字的总数。getBytes方法返回length加上汉字数,就是总的字节数。
只是使用了[^\x00-\xff],这个有点恶心,有些特殊字符也是能匹配到的,比如}等。
但是如果使用[^\u4E00-\u9FA5]的话,却不能匹配到中文……

posted on 2008-08-12 15:52 littleQ 阅读(6272) 评论(6)  编辑  收藏 所属分类: java

Feedback

# re: JS验证中文长度[未登录] 2008-08-12 20:19 MoXie
http://bbs.51js.com/viewthread.php?tid=79954

form.filter.js mb_strlen  回复  更多评论
  

# re: JS验证中文长度 2008-08-13 21:25 fyxruben
用length的话是33,但是到oracle里就是66个字节了

-------这个不一定,你数据要是是UTF-8可能就是99了  回复  更多评论
  

# re: JS验证中文长度[未登录] 2008-08-26 12:25 屹砾
UTF8可能是1-4个字节  回复  更多评论
  

# re: JS验证中文长度 2014-08-20 10:08 tytyutuyyututyutuytutyut
asdadasdadasdada  回复  更多评论
  

# re: JS验证中文长度 2014-08-20 10:08 tytyutuyyututyutuytutyut
dsfdsfsfdsf  回复  更多评论
  

# re: JS验证中文长度 2014-08-20 10:08 tytyutuyyututyutuytutyut
1212121212  回复  更多评论
  


只有注册用户登录后才能发表评论。


网站导航: