记录一下,在使用UITextView里的两个实用的小技巧
- 文本框插入自定义表情字符
如果要使用自己定义的表情键盘,我们就要自己处理在文字中插入表情的逻辑。
NSMutableString *tempStr = [self.textView.text mutableCopy];
NSRange range = [self.postView.textView selectedRange];
[tempStr insertString:emoji atIndex:range.location];
self.textView.text = tempStr;
self.postView.textView.selectedRange = NSMakeRange(length,0);
大致思路就是:获取当前输入框的text, 在光标所在的位置插入表情。最后把光标移动到表情后面。这样就可以继续输入了。
文本框加入字数限制
我们经常需要给输入框一个字数限制,通过在UITextView的代理方法中可以限制。
- (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text{
if (range.location >= MAX) {
return NO;
}
return YES;
}
但这个方法加了还不如不加。第一,在点击中文联想的文字进行输入时,不会触发该方法。第二,复制粘贴的长度大于限制,会出现无法删除的问题。
网上也有人针对这些问题分别进行了解决,但加起来几百行的代码为了这一个小需求实在有些说不过去。
下面提供一个稍微简单的方法:
@property (nonatomic, assign) NSInteger len;
- (void)textViewDidChange:(UITextView *)textView{
UITextRange *selectedRange = [textView markedTextRange];
if (selectedRange && pos) {
NSInteger tempLen = [textView offsetFromPosition:selectedRange.start toPosition:selectedRange.end];
if (tempLen != self.len) {
self.len = tempLen/2+1;
}
return;
}
if (textView.text.length>MAX) {
NSMutableString *tempStr = [self.textView.text mutableCopy];
[tempStr deleteCharactersInRange:NSMakeRange(range.location-self.len>MAX?MAX:range.location-self.len, self.len)];
self.len = 0;
textView.text = [tempStr substringToIndex:MAX>tempStr.length?tempStr.length:MAX];
}
这样就限制了字数,并且能处理复制粘贴内容和中文联想的问题,同事解决了中文插入的问题。
经过简单测试,没有发生异常情况,如果使用过程中有问题,欢迎留言。