JavaScript实现的GBK、UTF8字符串实际长度计算函数
作者:bea
大家都知道,在JS中字符串的长度不分中英文字符, 每一个字符都算一个长度,这跟PHP里的strlen()函数就不太一样。PHP里的strlen()函数根据字符集把GBK的中文每个2累加,把UTF-8的中文字符每个按3累加。 有些童鞋可能要问了,为什么要计算实际长度? 主要是为了匹配数据库的长度范围内,比如GBK的数据库某字段是varchar(10),那么就相当于5个汉字长度,一个汉字等于两个字母长度。如果是UTF8的数据库则是每个汉字长度为3。 知道了以上原理以后,我们就可以
大家都知道,在JS中字符串的长度不分中英文字符, 每一个字符都算一个长度,这跟PHP里的strlen()函数就不太一样。PHP里的strlen()函数根据字符集把GBK的中文每个2累加,把UTF-8的中文字符每个按3累加。
有些童鞋可能要问了,为什么要计算实际长度?
主要是为了匹配数据库的长度范围内,比如GBK的数据库某字段是varchar(10),那么就相当于5个汉字长度,一个汉字等于两个字母长度。如果是UTF8的数据库则是每个汉字长度为3。
知道了以上原理以后,我们就可以算出一个字符串的实际长度了,如果是GBK字符集遇到中文加2,如果是UTF8字符集遇到中文加3即可 GBK长度计算函数:
代码如下:
// GBK字符集实际长度计算
function getStrLeng(str){
var realLength = 0;
var len = str.length;
var charCode = -1;
for(var i = 0; i < len; i++){
charCode = str.charCodeAt(i);
if (charCode >= 0 && charCode <= 128) {
realLength += 1;
}else{
// 如果是中文则长度加2
realLength += 2;
}
}
return realLength;
}
UTF8长度计算函数:
代码如下:
// UTF8字符集实际长度计算
function getStrLeng(str){
var realLength = 0;
var len = str.length;
var charCode = -1;
for(var i = 0; i < len; i++){
charCode = str.charCodeAt(i);
if (charCode >= 0 && charCode <= 128) {
realLength += 1;
}else{
// 如果是中文则长度加3
realLength += 3;
}
}
return realLength;
}
有用 | 无用
有些童鞋可能要问了,为什么要计算实际长度?
主要是为了匹配数据库的长度范围内,比如GBK的数据库某字段是varchar(10),那么就相当于5个汉字长度,一个汉字等于两个字母长度。如果是UTF8的数据库则是每个汉字长度为3。
知道了以上原理以后,我们就可以算出一个字符串的实际长度了,如果是GBK字符集遇到中文加2,如果是UTF8字符集遇到中文加3即可 GBK长度计算函数:
代码如下:
// GBK字符集实际长度计算
function getStrLeng(str){
var realLength = 0;
var len = str.length;
var charCode = -1;
for(var i = 0; i < len; i++){
charCode = str.charCodeAt(i);
if (charCode >= 0 && charCode <= 128) {
realLength += 1;
}else{
// 如果是中文则长度加2
realLength += 2;
}
}
return realLength;
}
UTF8长度计算函数:
代码如下:
// UTF8字符集实际长度计算
function getStrLeng(str){
var realLength = 0;
var len = str.length;
var charCode = -1;
for(var i = 0; i < len; i++){
charCode = str.charCodeAt(i);
if (charCode >= 0 && charCode <= 128) {
realLength += 1;
}else{
// 如果是中文则长度加3
realLength += 3;
}
}
return realLength;
}
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- laytpl 精致巧妙的JavaScript模板引擎
- jQuery动画特效实例教程
- jQuery实用函数用法总结
- jQuery实现异步获取json数据的2种方式
- 原生javascript实现的分页插件pagenav
- JavaScript判断变量是对象还是数组的方法
- 分享一个自己动手写的jQuery分页插件
- jQuery标签替换函数replaceWith()的使用例子
- jQuery焦点图切换简易插件制作过程全纪录
- javascript正则表达式参数/g与/i及/gi的使用指南
- JavaScript数组函数unshift、shift、pop、push使用实例
- JavaScript实现的in_array函数
- JavaScript AJAX之惰性载入函数
- IE浏览器不支持getElementsByClassName的解决方法
- JavaScript中使用stopPropagation函数停止事件传播例子
- JavaScript闭包函数访问外部变量的方法
- JavaScript中switch判断容易犯错的一个细节
- JavaScript中使用arguments获得函数传参个数实例
- JavaScript中输出</script>标签的方法