Swift version: 5.2
Most of UIKit has a concept of responders baked deep into the system, but it’s not common you need to work with it directly. It’s Apple’s implementation of a design pattern called the Chain of Responsibility: UIKit asks one component if it can respond to an action, but if it can’t it gets passed to another component, and if that can’t respond then it gets passed on and on until something can respond – it’s a chain of responders.
The first responder is whatever control is currently ready to respond to actions. In UIKit this is usually the control that has activated the keyboard and is receiving input. If you want that text control to stop waiting for input – which in turn dismisses the keyboard – you should call its
resignFirstResponder() method, which passes the first responder baton to the next waiting component.
The responder chain is how events bubble upwards on Apple platforms:
touchesBegan() might be implemented on a view, on its view controller, on a parent view controller, or even higher up, but it will always be triggered somewhere when it happens.
SPONSORED Catch bugs as soon as they happen and know exactly why a crash occurred. Instabug's SDK grabs all the logs they need to fix bugs, crashes and performance issues in minutes instead of days. Get screenshots, device details, network logs, repro steps, and tons of other critical insights needed to resolve issues and prioritize product backlogs straight from your dashboard. It only takes a minute to integrate!
Available from iOS 2.0 – learn more in my book Swift Design Patterns
This is part of the Swift Knowledge Base, a free, searchable collection of solutions for common iOS questions.
Link copied to your pasteboard.