jquery 判断中文字符的长度

jquery 判断中文字符的长度

方法一:使用正则表达式,代码如下:

function getByteLen(val) {
            var len = 0;
            for (var i = 0; i < val.length; i++) {
                 var a = val.charAt(i);
                 if (a.match(/[^\x00-\xff]/ig) != null) 
                {
                    len += 2;
                }
                else
                {
                    len += 1;
                }
            }
            return len;
        }



方法二:使用字符unicode判断:方法如下:

function getByteLen(val) {
            var len = 0;
            for (var i = 0; i < val.length; i++) {
               var length = val.charCodeAt(i);
               if(length>=0&&length<=128)
                {
                    len += 1;
                }
                else
                {
                    len += 2;
                }
            }
            return len;
        }



function queryTask(){
    var taskNameQueryLength = getByteLen($("#taskNameQuery").val().trim());
    if(taskNameQueryLength>4){
        jAlert("任务名称长度为0-160位,其中中文算两个字符!", "系统提示");
        return;
    }
    var scanTargetQueryLength = getByteLen($("#scanTargetQuery").val().trim());
    if(scanTargetQueryLength>4){
        jAlert("扫描目标长度为0-65535位!", "系统提示");
        return;
    }
    gridQuery();

}
function getByteLen(val) {
    var len = 0;
    for (var i = 0; i < val.length; i++) {
         var patt = new RegExp(/[^\x00-\xff]/ig);
         var a = val[i];
         if (patt.test(a)) 
        {
            len += 2;
        }
        else
        {
            len += 1;
        }
    }
    return len;
}

2。根据字符截取,超长用。。。

var a =autoAddEllipsis("中国移动通信中国移动通信中国移动通信中国移动通信中国移动通信", 50);
var b =autoAddEllipsis("aaaaaaaaaabbbbbbbbbbccccccccccdddddddddd", 50);
alert(b)
/* 
 * 处理过长的字符串,截取并添加省略号 
 * 注:半角长度为1,全角长度为2 
 *  
 * pStr:字符串 
 * pLen:截取长度 
 *  
 * return: 截取后的字符串 
 */
function autoAddEllipsis(pStr, pLen) {

    var _ret = cutString(pStr, pLen);
    var _cutFlag = _ret.cutflag;
    var _cutStringn = _ret.cutstring;

    if ("1" == _cutFlag) {
        return _cutStringn + "...";
    } else {
        return _cutStringn;
    }
}

/* 
 * 取得指定长度的字符串 
 * 注:半角长度为1,全角长度为2 
 *  
 * pStr:字符串 
 * pLen:截取长度 
 *  
 * return: 截取后的字符串 
 */
function cutString(pStr, pLen) {

    // 原字符串长度  
    var _strLen = pStr.length;

    var _tmpCode;

    var _cutString;

    // 默认情况下,返回的字符串是原字符串的一部分  
    var _cutFlag = "1";

    var _lenCount = 0;

    var _ret = false;

    if (_strLen <= pLen / 2) {
        _cutString = pStr;
        _ret = true;
    }

    if (!_ret) {
        for (var i = 0; i < _strLen ; i++) {
            if (isFull(pStr.charAt(i))) {
                _lenCount += 2;
            } else {
                _lenCount += 1;
            }

            if (_lenCount > pLen) {
                _cutString = pStr.substring(0, i);
                _ret = true;
                break;
            } else if (_lenCount == pLen) {
                _cutString = pStr.substring(0, i + 1);
                _ret = true;
                break;
            }
        }
    }

    if (!_ret) {
        _cutString = pStr;
        _ret = true;
    }

    if (_cutString.length == _strLen) {
        _cutFlag = "0";
    }

    return { "cutstring": _cutString, "cutflag": _cutFlag };
}

/* 
 * 判断是否为全角 
 *  
 * pChar:长度为1的字符串 
 * return: true:全角 
 *          false:半角 
 */
function isFull(pChar) {
    if ((pChar.charCodeAt(0) > 128)) {
        return true;
    } else {
        return false;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值