Focus Trap
The Focus Trap component prevents the user's focus from escaping its children components.
Introduction
Focus Trap is a utility component that's useful when implementing an overlay such as a modal dialog, which should block all interactions outside of it while open.
Component
Usage
After installation, you can start building with this component using the following basic elements:
<span class="token keyword">import</span> FocusTrap <span class="token keyword">from</span> <span class="token string">'@mui/base/FocusTrap'</span><span class="token punctuation">;</span>
<span class="token keyword">export</span> <span class="token keyword">default</span> <span class="token keyword">function</span> <span class="token function">MyApp</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
<span class="token keyword">return</span> <span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">FocusTrap</span></span><span class="token punctuation">></span></span><span class="token punctuation">{</span><span class="token comment">/* children where the focus will be trapped */</span><span class="token punctuation">}</span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span><span class="token class-name">FocusTrap</span></span><span class="token punctuation">></span></span><span class="token punctuation">;</span>
<span class="token punctuation">}</span>
Basics
Focus Trap wraps around the UI elements that should hold the user's focus. For instance, if the focus needs to stay inside of an Menu, then the component will be structured like this:
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">FocusTrap</span></span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">Menu</span></span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">MenuItem</span></span><span class="token punctuation">></span></span><span class="token punctuation">{</span><span class="token comment">/* item one */</span><span class="token punctuation">}</span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span><span class="token class-name">MenuItem</span></span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">MenuItem</span></span><span class="token punctuation">></span></span><span class="token punctuation">{</span><span class="token comment">/* item two */</span><span class="token punctuation">}</span><span class="token tag"><span class="token tag"><span class="token punctuation"></</span><span class="token class-name">MenuItem</span></span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"></</span><span class="token class-name">Menu</span></span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"></</span><span class="token class-name">FocusTrap</span></span><span class="token punctuation">></span></span>
The following demo shows a <button>
that opens a Box component nested inside of a Focus Trap.
As long as the Box is open, the user's keyboard cannot interact with the rest of the app.
Press the Open button and then use the Tab key to move the focus—notice that it will not leave the Box:
Customization
Disable enforced focus
By default, clicks outside of the Focus Trap component are blocked.
You can disable this behavior with the disableEnforceFocus
prop.
Compare the following demo with the demo from the Basics section—notice how that demo prevents you from clicking outside of it, while this one allows it:
Lazy activation
By default, the Focus Trap component automatically moves the focus to the first of its children when the open
prop is present.
You can disable this behavior and make it lazy with the disableAutoFocus
prop.
When auto focus is disabled—as in the demo below—the component only traps the focus once the user moves it there:
Escape the focus loop
The following demo uses the Portal component to render a subset of the Focus Trap children into a new "subtree" outside of the current DOM hierarchy, so they are no longer part of the focus loop:
Using a toggle inside the trap
The most common use case for the Focus Trap component is to maintain focus within a Modal component that is entirely separate from the element that opens the modal.
But you can also create a toggle button for the open
prop of the Focus Trap component that is stored inside of the component itself, as shown in the following demo: