正则表达式:验证中英文长度限制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;
}
相关推荐
菜鸟小芯6 分钟前
【GLM-5 陪练式前端新手入门】第一篇:从 GLM-5 提示到实践,完成前端入门第一步
前端·人工智能
木斯佳10 分钟前
前端八股文面经大全:字节跳动交易与广告前端一面(2026-2-10)·面经深度解析
前端
Highcharts.js26 分钟前
如何根据派生数据创建钟形曲线图表?highcharts正态分布曲线使用指南:从创建到设置一文搞定
开发语言·javascript·开发文档·正态分布·highcharts·图表类型·钟形图
a11177631 分钟前
纸张生成器(html开源)
前端·开源·html
心.c36 分钟前
虚拟滚动列表
前端·javascript·vue.js·js
祯民1 小时前
《复合型 AI Agent 开发:从理论到实践》实体书上架
前端
NEXT061 小时前
深拷贝与浅拷贝的区别
前端·javascript·面试
不写八个1 小时前
PixiJS教程(一):快速搭建环境启动项目
前端·pixijs
PieroPc2 小时前
用html+css+js 写一个Docker 教程
javascript·css·docker·html
菜鸟小芯2 小时前
【GLM-5 陪练式前端新手入门】第二篇:CSS 让网页从 “能用” 变 “好看”
前端·css