您的位置:首页 > 产品设计 > UI/UE

如何更好地限制一个UITextField的输入长度

2015-06-05 11:38 459 查看
要限制一个UITextField的输入字数(参考链接),首先想到的应该是通过

UITextFieldDelegate


的代理方法来限制:

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string;   <span class="code-comment" style="color: rgb(128, 128, 128); background-color: inherit;">// <span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">return</span> NO to not change text</span>


比如要设置字数限制为20:

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string
{
<span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">if</span> (textField == self.titleField) {
<span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">if</span> (textField.length > 20) <span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">return</span> NO;
}

<span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">return</span> YES;
}


但是这样的限制简单粗暴,可能会影响用户正常逻辑下的输入,比如输入了20个字符后,要退格回删字符。

这时候我们可能会考虑“Detect backspace in UITextField”,比如简单地判断replacementString的长度是否为0

接着我们可能还会遇到用户已经输入20个字符了,这时候继续输入---不过是选择了部分文本进行替换-----无法进行了,这也妨碍了用户的正常操作,所以限制的代码版本可能会演进为:

#pragma mark - UITextFieldDelegate

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string
{
<span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">if</span> (textField == self.titleField) {
<span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">if</span> (string.length == 0) <span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">return</span> YES;

NSInteger existedLength = textField.text.length;
NSInteger selectedLength = range.length;
NSInteger replaceLength = string.length;
<span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">if</span> (existedLength - selectedLength + replaceLength > 20) {
<span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">return</span> NO;
}
}

<span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">return</span> YES;
}


到这里可能会觉得基本大功告成了,但是当你输入19个字符后,第20个字符以中文汉字的形式继续输入,那么系统会在键盘上方提供后续的一系列联想词,你会发现通过这种方式可以连续选字输入从而突破20个字符的限制。WTF

到了这里,我们可能会希望有个类似

- (void)textFieldDidChange:(UITextField *)textField


的回调方法,但可惜没有。

当然,我们还可以通过

- (void)textFieldDidEndEditing:(UITextField *)textField;


回调方法在结束编辑的时候把文本截断,虽然在用户体验上会有点突兀。

不过当我们点进去UITextField.h头文件里寻觅上述回调方法而不得时,可能会发现最下面有这么个消息通知名称:

UIKIT_EXTERN NSString *<span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">const</span> UITextFieldTextDidChangeNotification;


不过,监听消息还要记得解除监听,通常我还习惯把监听消息的代码统一放在一个方法中,看起来有点“大动干戈”。

所幸的是UITextField本身提供了相应的事件监听

[textField addTarget:self action:@selector(textFieldDidChange:) forControlEvents:UIControlEventEditingChanged];


这样就可以更好地限制输入长度:

- (void)textFieldDidChange:(UITextField *)textField
{
<span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">if</span> (textField == self.titleField) {
<span class="code-keyword" style="color: rgb(0, 0, 145); background-color: inherit;">if</span> (textField.text.length > 20) {
textField.text = [textField.text substringToIndex:20];
}
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: