欢迎您来到懒之才-站长的分享平台!   学会偷懒,并懒出境界是提高工作效率最有效的方法!
首页 > 经验分享 > Js&Ajax > Js判断中文限制文字字节数

Js判断中文限制文字字节数

2018-06-25 574 收藏 0 赞一个 0 真差劲 0 去评论

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

大家评论