Js判断中文限制文字字节数
Js限制文字字节本来比较容易实现,唯一值得注意的就是中文字符的判断,因为中文和英文所占的字节不一样,英文只占1个字节,而中文则需要2个,以下JavaScript函数是平时做项目时写的,经过了多次修正,应该比较准确了,后面会告诉你使用方法。先来主函数代码:
checkbyte.js代码:
function limitLength(value, byteLength, title, attribute) {
var newvalue = value.replace(/[^\x00-\xff]/g, "**");
var length = newvalue.length;
//当输入文字的字节数小于设定的字节数
if (length * 1 <=byteLength * 1){
return;
}
var limitDate = newvalue.substr(0, byteLength);
var count = 0;
var limitvalue = "";
for (var i = 0; i < limitDate.length; i++) {
var flat = limitDate.substr(i, 1);
if (flat == "*") {
count++;
}
}
var size = 0;
var istar = newvalue.substr(byteLength * 1 - 1, 1);//校验点是否为“×”
//if 基点是×; 判断在基点内有×为偶数还是奇数
if (count % 2 == 0) {
//当为偶数时
size = count / 2 + (byteLength * 1 - count);
limitvalue = value.substr(0, size);
} else {
//当为奇数时
size = (count - 1) / 2 + (byteLength * 1 - count);
limitvalue = value.substr(0, size);
}
alert(title + "最大输入" + byteLength + "个字节(相当于"+byteLength /2+"个汉字)!");
document.getElementById(attribute).value = limitvalue;
return;
}下面是例子,使用前请引入checkbyte.js
<textarea name="explain" id="explain" onkeyup="limitLength(value,5,'语义说明','explain')" > <!--或者这样写也可以:--> <input type="text" name="explain" id="explain" onkeyup="limitLength(value,5,'语义说明','explain')" >
value: 值
byteLength:数据库字节长度
title:字段中文名称
attribute:属性名称
使用说明:
1、onkeyup="limitLength(this.value,100,'名称','name')"
2、id="name" 或【struts标签】styleId="name"
这里要注意id和 attribute属性名称要一样
一、推荐使用迅雷或快车等多线程下载软件下载本站资源。
二、未登录会员无法下载,登录后可获得更多便利功能,若未注册,请先注册。
三、如果服务器暂不能下载请稍后重试!总是不能下载,请点我报错 ,谢谢合作!
四、本站大部分资源是网上搜集或私下交流学习之用,任何涉及商业盈利目的均不得使用,否则产生的一切后果将由您自己承担!本站将不对任何资源负法律责任.如果您发现本站有部分资源侵害了您的权益,请速与我们联系,我们将尽快处理.
五、如有其他问题,请加网站设计交流群(点击这里查看交流群 )进行交流。
六、如需转载本站资源,请注明转载来自并附带链接
七、本站部分资源为加密压缩文件,统一解压密码为:www.aizhanzhe.com
大家评论
站长推荐
