?在js里,一个中文字符的length是1,但是提交到数据库中,就占了两个字节,验证误差,直接抛异常,解决这个问题,我们可以在js中定义一个新的函数getBytes()取得字符串的字节数,在java里,这个函数是标准函数。
String.prototype.getBytes = function() { var cArr = this.match(/[^\x00-\xff]/ig); return this.length + (cArr == null ? 0 : cArr.length); } function CheckForm(str){ if(str.value.getBytes() > 64){ alert("字符超过64个字符"); return false; } return true; }
?getBytes用正则表达式来判断字符串中包含汉字的个数,包含的汉字都放到数组cArr中,这样cArr的长度就是汉字的总数。getBytes方法返回length加上汉字数,就是总的字节数...
?
?但是如果使用[^\u4E00-\u9FA5]的话,它只能识别中文,当一个input里面既有字符又有中文的话还是没法判断.....