虽然UITextField
类没有最大长度属性,但通过设置文本字段的delegate
并实现以下委托方法来获得此功能相对简单:
Objective-C个
- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string {
// Prevent crashing undo bug – see note below.
if(range.length + range.location > textField.text.length)
{
return NO;
}
NSUInteger newLength = [textField.text length] + [string length] - range.length;
return newLength <= 25;
}
Swift个
func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {
let currentCharacterCount = textField.text?.count ?? 0
if range.length + range.location > currentCharacterCount {
return false
}
let newLength = currentCharacterCount + string.count - range.length
return newLength <= 25
}
在文本字段更改之前,UITextField会询问学员是否更改了指定的文本字段.此时文本字段没有改变,所以我们获取它的当前长度和插入的字符串长度(通过粘贴复制的文本或使用键盘键入单个字符),减go 范围长度.如果该值太长(本例中超过25个字符),则返回NO
以禁止更改.
当在文本字段末尾键入单个字符时,range.location
将是当前字段的长度,range.length
将是0,因为我们不会替换/删除任何内容.插入到文本字段的中间只表示不同的range.location
,粘贴多个字符表示string
中有多个字符.
删除单个字符或剪切多个字符由长度非零的range
和空字符串指定.替换只是使用非空字符串的范围删除.
正如 comments 中提到的,有一个UITextField
的bug可能会导致崩溃.
如果粘贴到字段中,但验证实现阻止了粘贴,则粘贴操作仍会记录在应用程序的undo撤消缓冲区中.如果随后启动撤销(通过晃动设备并确认撤销),UITextField
将try 用空字符串替换它粘贴到自身的字符串.这将崩溃,因为它从未将字符串粘贴到自身中.它将try 替换字符串中不存在的部分.
幸运的是,你可以保护这UITextField
人不会像这样自杀.您只需要确保它建议替换does的范围存在于其当前字符串内.这就是上面的初始健全性判断所做的.
func textView(_ textView: UITextView, shouldChangeTextIn range: NSRange, replacementText text: String) -> Bool {
let str = (textView.text + text)
if str.characters.count <= 10 {
return true
}
textView.text = str.substring(to: str.index(str.startIndex, offsetBy: 10))
return false
}
希望对你有帮助.