关闭键盘 – iOS 7中的多个UITextFields

在下面你会找到我的主视图控制器的.h和.m文件。

我有3个问题。

1.)因为我有多个uitextfields,我是否必须使用自己的resignFirstResponder语句设置每个字段? 2.)我会用哪种方法做到这一点? 3.)我的语法是否适合辞职第一响应者?

如果我可以在用户点击字段时关闭键盘而不是点击返回键,那将是非常好的!

我知道之前已经被问到并回答了,但老实说,我仍然有点困惑,到底发生了什么。

我正在使用故事板,XCode 5和iOS 7。

=============================

.h文件

@interface ViewController : UIViewController  @property (weak, nonatomic) IBOutlet UITextField *danceDate; @property (weak, nonatomic) IBOutlet UITextField *dancePlace; @property (weak, nonatomic) IBOutlet UITextField *danceTerminal; @property (weak, nonatomic) IBOutlet UITextField *danceGate; 

.m文件

 #import "ViewController.h" @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; [self retrieveFromParse]; self.tableView.dataSource = self; self.tableView.delegate = self; self.navigationItem.rightBarButtonItem = self.editButtonItem; // SET DELEGATE HERE // // if I uncomment 1 of these lines, i'll get an error. // // _dancePlace.delegate = self; // dancePlace.delegate = self; // dancePlace = self; } - (void)textFieldDidBeginEditing:(UITextField *)textField { } -(BOOL) textFieldShouldReturn: (UITextField *) textField { [textField resignFirstResponder]; return YES; } -(BOOL) textFieldShouldReturn: (UITextField *) textField { return YES; } 

重新启动textField:所有textField.delegate都应设置为ViewController的对象。 然后实现下面的委托方法。

 -(BOOL) textFieldShouldReturn: (UITextField *) textField { [textField resignFirstResponder]; return YES; } 

要点击视图关闭键盘:向ViewController.view添加点按手势,如下所示:

 //declare a property to store your current responder @property (nonatomic, assign) id currentResponder; //in viewDidLoad: UITapGestureRecognizer *singleTap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(resignOnTap:)]; [singleTap setNumberOfTapsRequired:1]; [singleTap setNumberOfTouchesRequired:1]; [self.view addGestureRecognizer:singleTap]; [singleTap release]; //Implement the below delegate method: - (void)textFieldDidBeginEditing:(UITextField *)textField { self.currentResponder = textField; } //Implement resignOnTap: - (void)resignOnTap:(id)iSender { [self.currentResponder resignFirstResponder]; } // was missing ; after the call --> [self.currentResponder resignFirstResponder] // also in textFieldDidEndEditing set self.currentResponder = nil; 

请尝试以下方法:

 [[self view] endEditing:YES] 
  -(BOOL) textFieldShouldReturn: (UITextField *) textField{ [textField resignFirstResponder]; return YES; } 

还连接您的UITextField 代理

这个答案适用于iOS 7和arc,

  1. 用户触摸返回时关闭键盘:在ViewController中添加以下操作

     -(IBAction)textFieldReturn:(id)sender { [sender resignFirstResponder]; } 

接下来,在main.storyboard中选择textField并从连接检查器控件+将“End End On Exit”事件拖到视图控制器。

  1. 用户触摸背景时关闭键盘:在ViewController中实现以下方法

      - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event { UITouch *touch = [[event allTouches] anyObject]; if ([YOUR_TEXT_FIELD isFirstResponder] && [touch view] != YOUR_TEXT_FIELD) { [YOUR_TEXT_FIELD resignFirstResponder]; } [super touchesBegan:touches withEvent:event]; } 

这是我在代码中使用的内容。 它的效果很好,比其他答案更有效。

在yourviewcontroller.h中添加:

@property (nonatomic) UITapGestureRecognizer *tapRecognizer;

现在在.m文件中,将其添加到ViewDidLoad函数中:

 - (void)viewDidLoad { //Keyboard stuff tapRecognizer = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(didTapAnywhere:)]; tapRecognizer.cancelsTouchesInView = NO; [self.view addGestureRecognizer:tapRecognizer]; } 

另外,在.m文件中添加此函数:

 - (void)handleSingleTap:(UITapGestureRecognizer *) sender { [self.view endEditing:YES]; } 

当有问题的UITextField调用委托方法- (BOOL)textFieldShouldReturn:(UITextField*)textField它将自己作为参数传递。

因此,作为此方法的参数可用的特定textField是您关心的特定textField 。 在此委托方法中,您可以将其称为“textField”。

这意味着您应该使用Mirko Catalano建议在textField上调用resignFirstResponder而不是像您正在执行的单个属性。

Mirko建议validation代表确实被分配也是至关重要的。 您需要确保nib或storyboard中的所有UITextField都具有指向File的Owner的委托属性。 否则委托消息将无处可及,并立即被忽略!

尝试使用self.dancePlace.delegate = self; 而不是dancePlace.delegate = self; 设置UITextFieldDelegate。 那样有用吗?

在快速3:

  //Dismiss keyboard , When touch outside override func touchesBegan(_ touches: Set, with event: UIEvent?) { self.view.endEditing(true) }