input输入框限制中文汉字只能输入20个字符,英文10个字符!

iput输入框限制中文汉字只能输入10个字符,英文20个字符!

产品提了一个需求,要求输入框输入汉字的时候只能输入10个汉字 英文的话只能输入20个,当时不知道怎么做,后来通过百度查找到了答案。

@input绑定limitLength方法

limitLength(e) {
		let value = e.detail.value
		const split = value.split('');
		//判断一段文字里面有几个汉字跟英文
		const map = split.map((s, i) => {
			return (value.charCodeAt(i) >= 0 && value.charCodeAt(i) <= 128) ? 1 : 2;
		});
		//计算数组相加的综合
		let charLength = map.length > 0 && map.reduce((accumulator, currentValue, index) => {
			const count = accumulator +A currentValue;
			return count
		});
		//判断长度是否大于20 大于20调用字节截取
		if (charLength <= 20) {
			this.newData.name = value
		} else {
			//使用setTimeout方法异步修改input的值 直接修改不起作用
			setTimeout(() => {
				//调用字节截取内容的方法修改输入框的值
				this.newData.name = this.reBytesStr(this.newData.name, 20)
			}, 10)
		}
	},
	//通过字节截取字符串
			/**
			 * @param {String} str //要截取的字符串
			 * @param {Number} len //要截取的长度
			 */
			reBytesStr(str, len) {
				if ((!str && typeof(str) != 'undefined')) {
					return '';
				}
				var num = 0;
				var str1 = str;
				var str = '';
				for (var i = 0, lens = str1.length; i < lens; i++) {
					num += ((str1.charCodeAt(i) > 255) ? 2 : 1);
					if (num > len) {
						break;
					} else {
						str = str1.substring(0, i + 1);
					}
				}
				return str;
			}

以上就是我的解决方法。
补充:uni-app 设置maxlength 用户用手机自带输入法会在输入拼音的时候就导致无法打出完整的字。控制用户输入的长度也可以用这种方式,或者在提交按钮的时候校验字符长度

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值