156

Clicking in a textfield makes the keyboard appear. How do I hide it when the user presses the return key?

Cœur
  • 37,241
  • 25
  • 195
  • 267
aden
  • 1,907
  • 3
  • 16
  • 16
  • 13
    The 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 Answers12

299

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;

lal
  • 7,410
  • 7
  • 34
  • 45
Saurabh
  • 22,743
  • 12
  • 84
  • 133
63

In viewDidLoad declare:

[yourTextField setDelegate:self];

Then, include the override of the delegate method:

-(BOOL)textFieldShouldReturn:(UITextField *)textField
{
    [textField resignFirstResponder];
    return YES;
}
Kristen Waite
  • 1,385
  • 2
  • 15
  • 28
oscar castellon
  • 3,048
  • 30
  • 19
24

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
    }
}
Nikhil Manapure
  • 3,748
  • 2
  • 30
  • 55
Mohammad Zaid Pathan
  • 16,304
  • 7
  • 99
  • 130
15

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
}
Dharmesh Dhorajiya
  • 3,976
  • 9
  • 30
  • 39
Homam
  • 5,018
  • 4
  • 36
  • 39
3

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)
    }
}
dimpiax
  • 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
2

Try this,

[textField setDelegate: self];

Then, in textField delegate method

- (BOOL)textFieldShouldReturn:(UITextField *)textField {
    [textField resignFirstResponder];
    return YES;
}
Retterdesdialogs
  • 3,180
  • 1
  • 21
  • 42
Vineesh TP
  • 7,755
  • 12
  • 66
  • 130
2

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).

IronManGill
  • 7,222
  • 2
  • 31
  • 52
Matrix
  • 7,477
  • 14
  • 66
  • 97
2

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:

enter image description here

iphaaw
  • 6,764
  • 11
  • 58
  • 83
1

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()
    ...
}
feca
  • 1,119
  • 16
  • 14
1

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.

Alex
  • 11
  • 2
1

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];

Graycodder
  • 447
  • 5
  • 15
0
[textField resignFirstResponder];

Use this

Robert
  • 5,278
  • 43
  • 65
  • 115
DURGESH
  • 2,373
  • 1
  • 15
  • 13