在关系数据库中,字符型的字段是有严格的长度限制的,如果写入的字符串长度超过最大限制,会导致异常。虽然我们目前没有直接用到关系数据库,但是SAP中会遇到这个问题,因此需要根据字符串的长度在前端做一些控制和处理。
这里有一个问题,如果直接通过基础类String的length属性判断,得到的值是不准确的,因为这个值仅仅是字符数,而不是字节数,例如“高端OA事业部”,如果用length属性,得到的是7,但是这个字符串实际上是12字节长的。
如果仅仅判断一个字符串的长度是否超过了最大字节数的限制,可以通过如下脚本
str=str.replace(/[^/x00-/xff]/g,"**");
这样可以将所有的双字节字符都替换为单字节的标记,再用length属性就可以得出准确的字节数
如果需要根据最大字节数的限制,对已有的字符串进行截取,可以通过以下函数进行
/**
*功能:判断给定的字符串是否在指定的字节数内,如果超出指定的字节数,按参数指定的上限截*断
*参数说明:strVal 要判断的字符串 iMaxNum 允许的最大字节数
*返回值:重整之后的字符串,如果在允许字节数范围内,则原样返回,否则将返回按照最大上限截断后的字符串
*/
function interceptString(strVal,iMaxNum){
var cToken,iByteN=0; var strReturn=""; var reg = /[^/x00-/xff]/; //遍历并判断字符串中的每个字符是否是双字节的
for(var i=0;i cToken = strVal.substr(i,1); if (cToken.match(reg)){ iByteN += 2; if(iByteN>iMaxNum){ return strReturn; } }else{ iByteN += 1; } strReturn += cToken; if (iByteN==iMaxNum){ return strReturn; } }
}