上述方法 ,调用了三个重要方法
isInputRuleAndNumber 此方法对于 手写时出现的一些图案没有剔除
#pragma mark - 谓词条件限制
/**
pattern中,输入需要验证的通过的字符
小写a-z
大写A-Z
汉字u4E00-u9FA5
数字u0030-u0039
@param str 要过滤的字符
@return YES 只允许输入字母和汉字
*/
- (BOOL)isInputRuleAndNumber:(NSString *)str {
NSString *pattern = @"[a-zA-Zu4E00-u9FA5u0030-u0039]";
NSPredicate *pred = [NSPredicate predicateWithFormat:@"SELF MATCHES %@", pattern];
BOOL isMatch = [pred evaluateWithObject:str];
return isMatch;
}
字符计算 unicodeLengthOfString
参考iOS textField限制字符串长度 字符数
-(NSUInteger)unicodeLengthOfString:(NSString *) text {
NSUInteger asciiLength = 0;
for (NSUInteger i = 0; i < text.length; i++) {
unichar uc = [text characterAtIndex: i];
asciiLength += isascii(uc) ? 1 : 2;
}
return asciiLength;
}
当时想,当 字符数大于 最大字符数 就把 当前textField.text.length 减一取值,但是对于粘贴复制 超过 字符数不止一个长度时,就出现问题了。那么我们如何解决呢?
此处,我想到了使用递归,先判断,最后一个str,利用unicodeLengthOfString 我们就可以知道 最后str 的字符长度,不论是 字母、数字还是汉字,对于超出的字符数,进行判断,删除多余长度。
- (void )saveOKText:(NSString *)textStr
{
int overLength = (int)[self unicodeLengthOfString:textStr] - kMaxLength;//超出的字符数
if (overLength <= 0 ){
_field.text = textStr;
return;
}
NSString *lastStr = [textStr substringFromIndex:textStr.length-1];
if ([self unicodeLengthOfString:lastStr] >= 2) {
textStr = [textStr substringToIndex:textStr.length-1];
NSLog(@"%@",textStr);
if (overLength >0) {
NSLog(@"%@",textStr);
[self saveOKText:textStr];
}else{
_field.text = textStr;
return;
}
}else if ([self unicodeLengthOfString:lastStr] == 1) {
textStr = [textStr substringToIndex:textStr.length-1];
if (overLength >0) {
[self saveOKText:textStr];
}else{
_field.text = textStr;
return;
}
}
}










