Clicking in a textfield makes the keyboard appear. How do I hide it when the user presses the return key?
-
13The nice thing about Stack Overflow is that MANY questions have already been answered, especially simple ones. Therefore, please look for answers FIRST, before asking. See, it's simple: http://stackoverflow.com/search?q=iphone+hide+keyboard – Felixyz Aug 26 '10 at 10:57
-
This is a subclass of UITextfield that dynamically change the UIReturnKey according to text/string condition: https://github.com/codeinteractiveapps/OBReturnKeyTextField – CodeInteractive Oct 21 '15 at 01:09
-
@Felixyz, The first question there is ironically about Android. – Iulian Onofrei Oct 20 '20 at 15:26
-
@IulianOnofrei I suppose that might change from year to year. But it's nice to get a reply one decade later :) Not so nice to discover I wrote such a snarky comment ten years ago. (In my defense, perhaps, it wasn't as clear back then that snark is a rot that perpetually threatens to destroy everything that is nice about the internet.) – Felixyz Oct 27 '20 at 13:11
-
@Felixyz, Don't worry, I know the feeling :D – Iulian Onofrei Oct 27 '20 at 13:33
12 Answers
First make your file delegate for UITextField
@interface MYLoginViewController () <UITextFieldDelegate>
@end
Then add this method to your code.
- (BOOL)textFieldShouldReturn:(UITextField *)textField {
[textField resignFirstResponder];
return YES;
}
Also add self.textField.delegate = self;
-
1Curious, why is
not necessary? Usually you'll see a warning in this case. – pixelfreak Mar 10 '12 at 08:59 -
7if you make your file delegate using Interface Builder then
is not necessary in .h file.. – Saurabh Mar 10 '12 at 11:07 -
1adding
in .h file and set delegate in viewdidload [yourTextField setDelegate:self]; will complete it! – Umit Kaya Jul 16 '15 at 05:35 -
In viewDidLoad
declare:
[yourTextField setDelegate:self];
Then, include the override of the delegate method:
-(BOOL)textFieldShouldReturn:(UITextField *)textField
{
[textField resignFirstResponder];
return YES;
}

- 1,385
- 2
- 15
- 28

- 3,048
- 30
- 19
-
6+1 for the `setDelegate:` reminder. Definitely had forgotten and code wasn't working previously. – Piper Jan 18 '14 at 23:22
-
2Shouldn't this be textField, rather than yourTextField as it is being passed in? – Clive Jefferies Apr 09 '14 at 09:47
-
is a way of saying that declare the delegate of your textField – oscar castellon Oct 17 '14 at 20:18
-
1
Try this in Swift,
Step 1: Set delegate as self to your textField
textField.delegate = self
Step 2: Add this UITextFieldDelegate below your class declaration,
extension YourClassName: UITextFieldDelegate {
func textFieldShouldReturn(textField: UITextField) -> Bool {
textField.resignFirstResponder()
return true
}
}

- 3,748
- 2
- 30
- 55

- 16,304
- 7
- 99
- 130
In swift do like this:
First in your ViewController
implement this UITextFieldDelegate
For eg.
class MyViewController: UIViewController, UITextFieldDelegate {
....
}
Now add a delegate to a TextField
in which you want to dismiss the keyboard when return is tapped either in viewDidLoad
method like below or where you are initializing it.
For eg.
override func viewDidLoad() {
super.viewDidLoad()
myTextField.delegate = self
}
Now add this method.
func textFieldShouldReturn(textField: UITextField) -> Bool {
textField.resignFirstResponder()
return true
}

- 3,976
- 9
- 30
- 39

- 5,018
- 4
- 36
- 39
-
1
-
Appears (in current versions of Swift) there should be an underscore before "textField:" – Bryce Sandlund May 10 '18 at 07:14
Swift 4
Set delegate of UITextField
in view controller, field.delegate = self
, and then:
extension ViewController: UITextFieldDelegate {
func textFieldShouldReturn(_ textField: UITextField) -> Bool {
// don't force `endEditing` if you want to be asked for resigning
// also return real flow value, not strict, like: true / false
return textField.endEditing(false)
}
}

- 12,093
- 5
- 62
- 45
-
how would you handle wanting users to 'tab' to the next text field with the press of the return key, until the last one and then it resigns ? Also in SwiftUI. – Learn2Code Mar 15 '20 at 21:11
-
@Learn2Code make a manager, collect textfields and chain, the last one will trigger finish function. – dimpiax Mar 16 '20 at 10:46
Try this,
[textField setDelegate: self];
Then, in textField delegate method
- (BOOL)textFieldShouldReturn:(UITextField *)textField {
[textField resignFirstResponder];
return YES;
}

- 3,180
- 1
- 21
- 42

- 7,755
- 12
- 66
- 130
set delegate of UITextField
, and over ride, textFieldShouldReturn
method, in that method just write following two lines:
[textField resignFirstResponder];
return YES;
that's it. Before writing a code dont forget to set delegate of a UITextField
and set Return key type to "Done" from properties window.(command + shift + I).

- 7,222
- 2
- 31
- 52

- 7,477
- 14
- 66
- 97
Define this class and then set your text field to use the class and this automates the whole hiding keyboard when return is pressed automatically.
class TextFieldWithReturn: UITextField, UITextFieldDelegate
{
required init?(coder aDecoder: NSCoder)
{
super.init(coder: aDecoder)
self.delegate = self
}
func textFieldShouldReturn(_ textField: UITextField) -> Bool
{
textField.resignFirstResponder()
return true
}
}
Then all you need to do in the storyboard is set the fields to use the class:

- 6,764
- 11
- 58
- 83
You can connect "Primary Action Triggered" (right click on UITextField) with an IBAction and you can resign first responder (without delegation). Example (Swift 4):
@IBAction func textFieldPrimaryAction(_ sender: UITextField) {
sender.resignFirstResponder()
...
}

- 1,119
- 16
- 14
Ok, I think for a novice things might be a bit confusing. I think the correct answer is a mix of all the above, at least in Swift4.
Either create an extension or use the ViewController in which you'd like to use this but make sure to implement UITextFieldDelegate. For reusability's sake I found it easier to use an extension:
extension UIViewController : UITextFieldDelegate {
...
}
but the alternative works as well:
class MyViewController: UIViewController {
...
}
Add the method textFieldShouldReturn (depending on your previous option, either in the extension or in your ViewController)
func textFieldShouldReturn(_ textField: UITextField) -> Bool {
return textField.endEditing(false)
}
In your viewDidLoad method, set the textfield's delegate to self
@IBOutlet weak var myTextField: UITextField!
...
override func viewDidLoad() {
..
myTextField.delegte = self;
..
}
That should be all. Now, when you press return
the textFieldShouldReturn
should be called.

- 11
- 2
If you want to hide the keyboard for a particular keyboard use
[self.view resignFirstResponder];
If you want to hide any keyboard from view use [self.view endEditing:true];

- 447
- 5
- 15