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 用户用手机自带输入法会在输入拼音的时候就导致无法打出完整的字。控制用户输入的长度也可以用这种方式,或者在提交按钮的时候校验字符长度