正则表达式:备注名称长度限制16个字符(8个中文),中文字母数字或者下划线

版权声明:转载请注明来源 https://blog.csdn.net/weixin_41829196/article/details/89360186

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

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

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:

	//设置备注名称
			setRemark : function () {
				if(!this.nickFlag){
					shareService.setRemarkName(this,{
						buddyId : this.buddyId,
						remark :	this.remarkName
					})
				}

			},
			//检查备注名
			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;
			}

猜你喜欢

转载自blog.csdn.net/weixin_41829196/article/details/89360186