Ответы:
Сначала вам нужно соответствовать UITextFieldDelegate
протоколу в заголовочном файле View / ViewController следующим образом:
@interface YourViewController : UIViewController <UITextFieldDelegate>
Затем в вашем .m файле вам необходимо реализовать следующий UITextFieldDelegate
метод протокола:
- (BOOL)textFieldShouldReturn:(UITextField *)textField
{
[textField resignFirstResponder];
return YES;
}
[textField resignFirstResponder];
Убедитесь, что клавиатура закрыта.
Убедитесь, что вы устанавливаете свой view / viewcontroller как делегат UITextField после инициализации текстового поля в .m:
yourTextField = [[UITextField alloc] initWithFrame:yourFrame];
//....
//....
//Setting the textField's properties
//....
//The next line is important!!
yourTextField.delegate = self; //self references the viewcontroller or view your textField is on
См. Управление клавиатурой для полного обсуждения этой темы.
Ваш UITextFields должен иметь объект делегата (UITextFieldDelegate). Используйте следующий код в своем делегате, чтобы клавиатура исчезла:
- (BOOL)textFieldShouldReturn:(UITextField *)textField {
[textField resignFirstResponder];
}
Должно работать пока ...
При нажатии клавиши возврата вызовите:
[uitextfield resignFirstResponder];
После довольно долгого поиска чего-то, что имеет смысл, я собрал это воедино, и это сработало как шарм.
.час
//
// ViewController.h
// demoKeyboardScrolling
//
// Created by Chris Cantley on 11/14/13.
// Copyright (c) 2013 Chris Cantley. All rights reserved.
//
#import <UIKit/UIKit.h>
@interface ViewController : UIViewController <UITextFieldDelegate>
// Connect your text field to this the below property.
@property (weak, nonatomic) IBOutlet UITextField *theTextField;
@end
.m
//
// ViewController.m
// demoKeyboardScrolling
//
// Created by Chris Cantley on 11/14/13.
// Copyright (c) 2013 Chris Cantley. All rights reserved.
//
#import "ViewController.h"
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad
{
[super viewDidLoad];
// _theTextField is the name of the parameter designated in the .h file.
_theTextField.returnKeyType = UIReturnKeyDone;
[_theTextField setDelegate:self];
}
// This part is more dynamic as it closes the keyboard regardless of what text field
// is being used when pressing return.
// You might want to control every single text field separately but that isn't
// what this code do.
-(void)textFieldShouldReturn:(UITextField *)textField
{
[textField resignFirstResponder];
}
@end
Надеюсь это поможет!
Установите делегата UITextField на свой ViewController, добавьте ссылку для выхода между владельцем файла и UITextField, затем реализуйте этот метод:
-(BOOL)textFieldShouldReturn:(UITextField *)textField
{
if (textField == yourTextField)
{
[textField resignFirstResponder];
}
return NO;
}
Добавьте это вместо предопределенного класса
class ViewController: UIViewController, UITextFieldDelegate {
Чтобы удалить клавиатуру при нажатии вне клавиатуры
override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?) {
self.view.endEditing(true)
}
и убрать клавиатуру при нажатии Enter
добавьте эту строку в viewDidLoad ()
inputField - это имя используемого текстового поля.
self.inputField.delegate = self
и добавьте эту функцию
func textFieldShouldReturn(textField: UITextField) -> Bool {
textField.resignFirstResponder()
return true
}
Swift 2:
это то, что сделал, чтобы сделать все!
закрыть клавиатуру с помощью Done
кнопки или Touch outSide
, Next
чтобы перейти к следующему вводу.
Первое изменение TextFiled Return Key
Чтобы Next
в раскадровке.
override func viewDidLoad() {
txtBillIdentifier.delegate = self
txtBillIdentifier.tag = 1
txtPayIdentifier.delegate = self
txtPayIdentifier.tag = 2
let tap = UITapGestureRecognizer(target: self, action: "onTouchGesture")
self.view.addGestureRecognizer(tap)
}
func textFieldShouldReturn(textField: UITextField) -> Bool {
if(textField.returnKeyType == UIReturnKeyType.Default) {
if let next = textField.superview?.viewWithTag(textField.tag+1) as? UITextField {
next.becomeFirstResponder()
return false
}
}
textField.resignFirstResponder()
return false
}
func onTouchGesture(){
self.view.endEditing(true)
}
быстро вы должны делегировать UITextfieldDelegate , важно не забывать об этом в viewController, например:
class MyViewController: UITextfieldDelegate{
mytextfield.delegate = self
func textFieldShouldReturn(textField: UITextField) -> Bool {
textField.resignFirstResponder()
}
}
Вы можете добавить IBAction к uiTextField (событие выпуска - «Did End On Exit»), а IBAction может называть hideKeyboard,
-(IBAction)hideKeyboard:(id)sender
{
[uitextfield resignFirstResponder];
}
Кроме того, вы можете применить его к другим текстовым полям или кнопкам, например, вы можете добавить скрытую кнопку в представление, когда вы щелкаете по ней, чтобы скрыть клавиатуру.
Вы можете попробовать этот подкласс UITextfield, в котором вы можете установить условие для текста для динамического изменения UIReturnKey:
https://github.com/codeinteractiveapps/OBReturnKeyTextField