首先,在做输入限制长度时,使用- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string此代理方法会导致中文拼音输入时预输入状态被计算入限制长度中,
导致拼音拼写时不能超出限制长度的范围。在经历了大量折磨后,终于找到了解决办法。
1.在UITextView中,使用- (void)textViewDidChange:(UITextView *)textView;方法可以完美解决。
2.而在UITextField中,可以使用- (void)textViewDidChangeSelection:(UITextField *)textField;这个方法。
思路:首先获取高亮范围,如果高亮范围存在,就return掉。然后判断输入文本的长度是否超出限制长度,
如果超出限制长度就从头截取到限制长度的文本内容,将它赋值给textFiled的文本,就能简单解决掉这个问题。
附简单代码:
- (void)textViewDidChangeSelection:(UITextField *)textField{
//获取高亮范围
UITextRange *range = [textFiled markedTextRange];
if(range){
return;
}
//判断长度是否超出限制
if(textField.text.length > max){//max为限制长度
textField.text = [textField.text subStringToIndex:max];
}
}
在做限制长度判断时,有时需要统一中英文长度。在此,推荐给NSString增加分类去实现。在判断长度时,就可以使用分类方法去判断文本的
字节长度,视中文为2个字节,英文为1个字节。
- (int)convertToInt{
int strlength = 0;
NSStringEncoding encoding = strtemp CFStringConvertEncodingToNSStringEncoding:(kCFStringEncodingGB_18030_2000);
char* p = (char*)[self cStringUsingEncoding:NSUnicodeStringEncoding];
for (int i=0 ; i<[self lengthOfBytesUsingEncoding:encoding] ;i++) {
if (*p) {
p++;
strlength++;
}
else {
p++;
}
}
return strlength;
}
同样,在使用这个方法在截取字符串时也需要添加根据字节长度截取的方法了。
-(NSString*)subTextString:(NSString*)str len:(NSInteger)len{
if(str.length<=len)return str;
int count=0;
NSMutableString *sb = [NSMutableString string];
for (int i=0; i<str.length; i++) {
NSRange range = NSMakeRange(i, 1) ;
NSString *aStr = [str substringWithRange:range];
count += [aStr lengthOfBytesUsingEncoding:NSUTF8StringEncoding]>1?2:1;
[sb appendString:aStr];
if(count >= len*2) {
return (i==str.length-1)?[sb copy]:[NSString stringWithFormat:@"%@...",[sb copy]];
}
}
return str;