我遇到了以下问题,不确定这是否是 iOS 错误,或者我误解了 UITextViewDelegate 回调。仅当我使用软件键盘(即使用鼠标单击屏幕键盘)时,我才能在我的设备(iPad Retina)和模拟器上重现此行为。
考虑以下人为设计的示例项目(2014 年 1 月 9 日更新): https ://www.dropbox.com/s/1q3vqfnsmmbhnuj/AutocorrectBug.zip
这是一个简单的 UITextView,将视图控制器设置为其委托,具有以下委托方法:
- (BOOL) textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text {
if ([text isEqualToString:@" "]
&& range.length == 0
&& (range.location == 0
|| [[textView.text substringWithRange:NSMakeRange(range.location-1, 1)] isEqualToString:@"\n"])) {
textView.backgroundColor = [UIColor yellowColor];
return NO;
}
return YES;
}
我对这段代码的意图是,当用户键入一个空格(编辑:并且该空格是该行的第一个字符)时,该空格被忽略,而是发生了一些其他功能,在这种情况下 UITextView 变为黄色。
现在考虑以下步骤:
- 点击文本视图使其成为第一响应者
- 输入“Apple”,回车并记下定位
- 现在,输入一个空格(将文本视图变为黄色),再次输入“Apple”并回车。
预期:黄色背景和文字阅读:
Apple
Apple
观察到:黄色背景和文字阅读(由于自动更正):
Apple
Apple
看来自动更正逻辑忽略了 textView:shouldChangeTextInRange:replacementText: 的结果。
- 这是预期的行为吗?
- 如果是这样,它可以解决吗?
编辑 1/9/14:只有一行上的第一个空格应该被忽略,进一步的空格应该正常处理(即插入到文本中),排除了蛮力的空格条。此外,我正在文本编辑器中处理一个大字符串(可能有数十万个字符)(意味着不断的用户输入),因此每次击键都分析整个字符串不会是高效的。