|  | 2 سال پیش | |
|---|---|---|
| .. | ||
| README.md | 2 سال پیش | |
| debounce.d.ts | 2 سال پیش | |
| debounce.js | 2 سال پیش | |
| debounce.js.map | 2 سال پیش | |
| focus-trap.d.ts | 2 سال پیش | |
| focus-trap.js | 2 سال پیش | |
| focus-trap.js.map | 2 سال پیش | |
| focusable.d.ts | 2 سال پیش | |
| focusable.js | 2 سال پیش | |
| focusable.js.map | 2 سال پیش | |
| index.d.ts | 2 سال پیش | |
| index.js | 2 سال پیش | |
| index.js.map | 2 سال پیش | |
| package.json | 2 سال پیش | |
| shadow.d.ts | 2 سال پیش | |
| shadow.js | 2 سال پیش | |
| shadow.js.map | 2 سال پیش | |
A lightweight web component that traps focus within a DOM node
A focus trap ensures thattab and shift + tab keys will cycle through the focus trap's tabbable elements but not leave the focus trap. This is great for making accessible modals. Go here to see a demo https://appnest-demo.firebaseapp.com/focus-trap/.
npm i @a11y/focus-trap
Import @a11y/focus-trap somewhere in your code and you're ready to go! Simply add the focus trap to your html and it'll be working without any more effort from your part.
<focus-trap>
  <button>Focus 1</button>
  <button>Focus 2</button>
  <button>Focus 3</button>
  <button>Focus 4</button>
  <button>Focus 5</button>
</focus-trap>
The focus-trap element implements the following interface.
interface IFocusTrap {
  // Returns whether or not the focus trap is inactive.
  inactive: boolean;
  // Returns whether the focus trap currently has focus.
  readonly focused: boolean;
  // Focuses the first focusable element in the focus trap.
  focusFirstElement: (() => void);
  // Focuses the last focusable element in the focus trap.
  focusLastElement: (() => void);
  // Returns a list of the focusable children found within the element.
  getFocusableElements: (() => HTMLElement[]);
}
Licensed under MIT.