Программно выделить весь текст в UITextField
Как программно выделить весь текст в UITextField?
12 ответов
Оказывается, вызывая -selectAll: с не ноль-отправителем отображает меню. Вызов с нулем заставляет его выделять текст, но не отображать меню.
Я попробовал это после того, как мой отчет об ошибке вернулся из Apple с предложением передать nil вместо self.
Не нужно гадить с UIMenuController или другими API выбора.
Вот что сделал трюк для меня:
[self.titleField setSelectedTextRange:[self.titleField textRangeFromPosition:self.titleField.beginningOfDocument toPosition:self.titleField.endOfDocument]];
Довольно некрасиво, но это работает, поэтому не будет отображаться sharedMenuController!
Для устранения проблемы "работает только каждый второй раз" используйте следующее:
__weak typeof(self) weakSelf = self;
dispatch_async(dispatch_get_main_queue(), ^{
__strong __typeof(weakSelf) strongSelf = weakSelf;
UITextRange *range = [strongSelf textRangeFromPosition:strongSelf.beginningOfDocument toPosition:strongSelf.endOfDocument];
[strongSelf setSelectedTextRange:range];
});
Спасибо Эрику Бейкеру (только что отредактировано из комментария здесь)
Используйте то, что вам нужно
[yourtextField becomeFirstResponder]; //puts cursor on text field
[yourtextField selectAll:nil]; //highlights text
[yourtextField selectAll:self]; //highlights text and shows menu(cut copy paste)
Я только что проверил это, чтобы подтвердить комментарий Мирко выше, но мой тест подтверждает, что selectAll:
фактически выделяет весь текст, когда он отправляется в сам UITextField.
Обратите внимание, что текст будет немедленно скрыт с помощью CUT | КОПИЯ | Вставьте действия, но на ваш вопрос, это именно то, что появляется, когда пользователь нажимает "Выбрать все" для начала.
Решение, с которым я собираюсь пойти дальше, обратите внимание, что вторая строка временно скрывает диалог CUT/COPY/PASTE, не отключая его для явного выбора пользователя
[_myTextField selectAll:self];
[UIMenuController sharedMenuController].menuVisible = NO;
Это лучшее решение, которое я нашел. Нет sharedMenuController, и он работает последовательно:
-(void)textFieldDidBeginEditing:(UITextField *)textField
{
[textField performSelector:@selector(selectAll:) withObject:nil afterDelay:0.1];
}
стриж
Выделить весь текст в UITextField
:
textField.selectedTextRange = textField.textRangeFromPosition(textField.beginningOfDocument, toPosition: textField.endOfDocument)
Мой полный ответ здесь.
Чтобы можно было выбрать текст, текстовое поле должно быть редактируемым. Чтобы узнать, когда текстовое поле доступно для редактирования, используйте методы делегата:
- (void)textFieldDidBeginEditing:(UITextField *)textField
- (BOOL)textFieldShouldBeginEditing:(UITextField *)textField
Я не думаю, что textFieldShouldBeginEditing: требуется, но это то, что я использовал в моей реализации.
- (void)textFieldDidBeginEditing:(UITextField *)textField{
[textField selectAll:textField];
}
- (BOOL)textFieldShouldBeginEditing:(UITextField *)textField{
return YES;
}
Передача в ноль, чтобы выбрать все: не будет отображать меню.
К сожалению, я не думаю, что вы можете сделать это.
Я не уверен, поможет ли это вам, но setClearsOnBeginEditing
позволяет указать, что UITextField
следует удалить существующее значение, когда пользователь начинает редактирование (это значение по умолчанию для безопасного UITextFields
).
Я создаю пользовательский вид оповещения, который содержит UITextField
внутри. Я нашел проблему с текстовым полем в том, что: beginningOfDocument
имеет значение, только если текстовое поле добавлено на экран & becomeFirstResponder
называется.
Иначе beginningOfDocument
возвращается nil
а также [UITextField textRangeFromPosition:]
не может получить значение.
Вот мой пример кода для решения этого случая.
UIWindow *window = [[[UIApplication sharedApplication] windows] firstObject];
[window addSubview:theAlertView]; // textfield must be added as a subview of screen first
UITextField *textField = theAlertView.textField;
[textField becomeFirstResponder]; // then call to show keyboard and cursor
UITextRange *range = [textField textRangeFromPosition:textField.beginningOfDocument toPosition:textField.endOfDocument]; // at this time, we could get beginningOfDocument
[textField setSelectedTextRange:range]; // Finally, it works!!!
UITextField *tf = yourTF;
// hide cursor (you have store default color!!!)
[[tf valueForKey:@"textInputTraits"] setValue:[UIColor clearColor]
forKey:@"insertionPointColor"];
// enable selection
[tf selectAll:self];
// insert your string here
// and select nothing (!!!)
[tf setMarkedText:@"Egor"
selectedRange:NSMakeRange(0, 0)];
Готово!
Если вы имеете в виду, как вы позволите пользователю редактировать текст в поле uitext, то просто назначьте ему firstResponder:
[textField becomeFirstResponder]
Если вы имеете в виду, как вы получаете текст в поле uitext, тогда это будет сделано:
textField.text
Если вы имеете в виду на самом деле выделите текст (как выделите его), это может быть полезно: