分享网正式开通,我们为大家提供免费资源,欢迎大家踊跃投稿!

利用JS实现对输入文字个数限制的方法

发表留言或者微博的时候,对输入文字个数的限制,下面分两种情况,每种分别介绍两种实现方式:

第一种:一个汉字算一位,两个字母或符号算一位

通过ASCII编码来判断


textarea.onkeyup = function(){
        //[^\x00-\xff]即ASCII编码不在0-255的字符,也就是汉子了,先把所有汉子换成任意两个字符,最后除以2,得到一个字符
        var n = 150- Math.floor(this.value.replace(/[^\x00-\xff]/g,"aa").length/2)
        span.innerHTML = n <=0 ? 0 : n;
};
 

通过charCodeAt编码来判断


//键盘up的时候判断
textarea.onkeyup = function(){
        var n = 1 ; //字母或符号累加判断
        var num = 0; //总个数累加判断
        for (var i = 0; i < this.value.length; i++) {
                //根据charCodeAt来判断输入的是中文还是字母,符号
                charCode = this.value.charCodeAt(i);
                if (charCode >= 0 && charCode <= 128){
                        //通过n模2来判断输入两次累加
                        n++;
                        if(n%2 == 0) num += 1;
                }else{
                        num += 1;
                }
        };
        span.innerHTML = 150-num <=0 ? 0 : 150-num;
};
 

另一种:是一个汉字算两位,一个字母或者符号算一位

通过ASCII编码来判断


textarea.onkeyup = function(){
        //[^\x00-\xff]即ASCII编码不在0-255的字符,也就是汉子了,先把所有汉子换成任意两个字符
        var n = 150- this.value.replace(/[^\x00-\xff]/g,"aa").length
        span.innerHTML = n <=0 ? 0 : n;
};
 

通过charCodeAt编码来判断


//键盘up的时候判断
textarea.onkeyup = function(){
        var num = 0; //总个数累加判断
        for (var i = 0; i < this.value.length; i++) {
                //根据charCodeAt来判断输入的是中文还是字母,符号
                charCode = this.value.charCodeAt(i);
                if (charCode >= 0 && charCode <= 128){
                        //字符就+1
                        num += 1;
                }else{
                        //汉子就+2
                        num += 2;
                }
        };
        span.innerHTML = 150-num <=0 ? 0 : 150-num;
};
 
资源均来自第三方,谨慎下载,前往第三方网站下载


爱资源分享网 , 版权所有丨本站资源仅限于学习研究,严禁从事商业或者非法活动!丨本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:利用JS实现对输入文字个数限制的方法
喜欢 ()分享 (0)