Как реализовать Dropdown меню?

Middle
235 просмотров
AFK Offer AI

Trigger кнопка + выпадающий список. Click outside закрывает: useEffect с document.addEventListener("click"), проверяешь event.target не внутри dropdown (ref.contains). Escape закрывает. Keyboard: ArrowDown/Up навигация, Enter выбор, Tab закрытие. aria-expanded, aria-haspopup на кнопке. role="menu", role="menuitem" на пунктах. Позиционирование: Floating UI для auto-flip. Focus management: при открытии фокус на первый пункт. Nested dropdown: submenu при hover на пункт с задержкой.

Следующий вопрос

Какие подводные камни у React.memo?