textfield 限制长度 iOS
2016-07-22 10:21
513 查看
要限制一个UITextField的输入字数(参考链接),首先想到的应该是通过
的代理方法来限制:
比如要设置字数限制为20:
但是这样的限制简单粗暴,可能会影响用户正常逻辑下的输入,比如输入了20个字符后,要退格回删字符。
这时候我们可能会考虑“Detect backspace in UITextField”,比如简单地判断replacementString的长度是否为0。
接着我们可能还会遇到用户已经输入20个字符了,这时候继续输入---不过是选择了部分文本进行替换-----无法进行了,这也妨碍了用户的正常操作,所以限制的代码版本可能会演进为:
到这里可能会觉得基本大功告成了,但是当你输入19个字符后,第20个字符以中文汉字的形式继续输入,那么系统会在键盘上方提供后续的一系列联想词,你会发现通过这种方式可以连续选字输入从而突破20个字符的限制。WTF
到了这里,我们可能会希望有个类似
的回调方法,但可惜没有。
当然,我们还可以通过
回调方法在结束编辑的时候把文本截断,虽然在用户体验上会有点突兀。
不过当我们点进去UITextField.h头文件里寻觅上述回调方法而不得时,可能会发现最下面有这么个消息通知名称:
不过,监听消息还要记得解除监听,通常我还习惯把监听消息的代码统一放在一个方法中,看起来有点“大动干戈”。
所幸的是UITextField本身提供了相应的事件监听:
这样就可以更好地限制输入长度:
方法一
- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
if (range.location>= 11)
return NO;
returnYES;
}
方法二
- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
NSString * toBeString = [textField.text stringByReplacingCharactersInRange:range withString:string];
if (toBeString.length > 11) {
textField.text = [toBeString substringToIndex:11];
return NO;
}
returnYES;
}
当前光标位置 range.location
已选文字长度 range.length
输入文字长度 textView.text.length
已有文字长度 text.length
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]; } } }
方法一
- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
if (range.location>= 11)
return NO;
returnYES;
}
方法二
- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
NSString * toBeString = [textField.text stringByReplacingCharactersInRange:range withString:string];
if (toBeString.length > 11) {
textField.text = [toBeString substringToIndex:11];
return NO;
}
returnYES;
}
当前光标位置 range.location
已选文字长度 range.length
输入文字长度 textView.text.length
已有文字长度 text.length
相关文章推荐
- 峰回路转,Firefox 浏览器即将重返 iOS 平台
- 峰回路转,Firefox 浏览器即将重返 iOS 平台
- 不可修补的 iOS 漏洞可能导致 iPhone 4s 到 iPhone X 永久越狱
- iOS 12.4 系统遭黑客破解,漏洞危及数百万用户
- 每日安全资讯:NSO,一家专业入侵 iPhone 的神秘公司
- [转][源代码]Comex公布JailbreakMe 3.0源代码
- extjs form textfield的隐藏方法
- 讲解iOS开发中基本的定位功能实现
- iOS中定位当前位置坐标及转换为火星坐标的方法
- js判断客户端是iOS还是Android等移动终端的方法
- iOS应用开发中AFNetworking库的常用HTTP操作方法小结
- iOS应用中UISearchDisplayController搜索效果的用法
- iOS App开发中的UISegmentedControl分段组件用法总结
- IOS开发环境windows化攻略
- iOS应用中UITableView左滑自定义选项及批量删除的实现
- iOS中UIAlertView警告框组件的使用教程
- 浅析iOS应用开发中线程间的通信与线程安全问题
- iOS中的UIKeyboard键盘视图使用方法小结
- 检测iOS设备是否越狱的方法