正则表达式:验证中英文长度限制16个字符(8个中文),支持中文字母数字或者下划线

1.中文字母数字或者下划线

2.长度限制16个字符(8个中文)

html:

html 复制代码
<input class="form-control text" maxlength="17" name="name" placeholder="输入16个字符以内的备注名称" type="text" v-model.trim="remarkName" value="" @keyup="checkNickName">
<span style="color: red;display:block;margin-top:10px" v-show="nickFlag">{{errorMsg}}</span>

js:

javascript 复制代码
//正则验证
checkNickName: function () {
    var reg = /^[a-zA-Z0-9_\u4e00-\u9fa5]+$/;//中文,数字,字母,下划线
    // console.log(this.computedStrLen(this.remarkName), '...');
    if (!reg.test(this.remarkName)) {
        this.errorMsg = '备注名称中不能包含特殊符号';
        this.nickFlag = true
    } else {
        if (this.computedStrLen(this.remarkName) > 16) {
            this.errorMsg = '最多输入16个字符(1个汉字2个字符)';
            this.nickFlag = true
        } else {
            this.nickFlag = false
        }
    }

},
//计算字符串长度,英文1个字符,中文2个字符
computedStrLen: function (str) {
    var len = 0;
    for (var i = 0; i < str.length; i++) {
        var c = str.charCodeAt(i);
        //单字节加1
        if ((c >= 0x0001 && c <= 0x007e) || (0xff60 <= c && c <= 0xff9f)) {
            len++;
        }
        else {
            len += 2;
        }
    }
    return len;
}
相关推荐
翻斗花园岭第一爆破手几秒前
flutter3.Container中的decoration
开发语言·前端·javascript
IT_陈寒4 分钟前
Java 21虚拟线程实战:7个性能翻倍的异步重构案例与避坑指南
前端·人工智能·后端
锅挤4 分钟前
Vue2:小水一下(5)
前端·javascript·html
翻斗花园岭第一爆破手5 分钟前
flutter2:Container的简介与尺寸
java·服务器·前端
倔强的小石头_13 分钟前
Python 从入门到实战(十四):Flask 用户认证(给 Web 应用加安全锁,区分管理员与普通用户)
前端·python·flask
be or not to be17 分钟前
前端基础实战笔记:文档流 + 盒子模型
前端·笔记
程序员码歌18 分钟前
短思考第264天,每天复盘5分钟,胜过你盲目努力1整年(2)
前端·后端·ai编程
nono牛19 分钟前
实战项目:设计一个智能温控服务
android·前端·网络·算法
敲敲了个代码7 小时前
从硬编码到 Schema 推断:前端表单开发的工程化转型
前端·javascript·vue.js·学习·面试·职场和发展·前端框架
dly_blog9 小时前
Vue 响应式陷阱与解决方案(第19节)
前端·javascript·vue.js