• Empleos
  • Sobre nosotros
  • Empleos
    • Inicio
    • Empleos
    • Cursos y retos
  • Empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Contrata talento tech
    • Blog
    • Comercial
    • Calculadora de salario

0

267
Vistas
Implementando el menú desplegable de React

Estoy creando un menú Dropdown usando React.
Pero no tengo idea de cómo implementar handleClose() .

ingrese la descripción de la imagen aquí

Quiero:

  1. Al hacer clic en el cuerpo/cualquier cosa fuera de <Dropdown> => handleClose()
  2. Al hacer clic en cualquier <ActionMenu> => handleClose()
  3. Hacer clic en cualquier elemento secundario dentro del <ActionMenu> => handleClose() si no se llamó a preventDefault()
  4. Al hacer clic en cualquier <ActionMenu enabled={false}> => no hacer nada
  5. Al hacer clic en cualquier niño dentro del <ActionMenu enabled={false}> => no hacer nada
  6. Al hacer clic en cualquier niño discapacitado dentro del <ActionMenu> => no hacer nada
  7. Al hacer clic en cualquier <NonActionMenu> => no hacer nada
  8. Al hacer clic en cualquier niño dentro del <NonActionMenu> => no hacer nada
  9. <Dropdown> perdió el foco ( onBlur= ) porque un elemento fuera del menú desplegable obtuvo el foco => handleClose()
  10. <Dropdown> perdió el foco ( onBlur= ) porque un elemento dentro del menú desplegable se centró => no hacer nada

La implementación <Dropdown onBlur={() => handleClose()} ...> funciona para el punto 9 pero falló para el punto 10.

¿Puedes sugerir tu idea?

No tengo sandbox porque el proyecto es bastante complejo.
Pero puedes bifurcar y modificar aquí: mi proyecto

almost 4 years ago · Juan Pablo Isaza
1 Respuestas
Responde la pregunta

0

Para el clic, puede agregar un detector de eventos al objeto de la ventana para encargarse de cualquier clic fuera del contenedor desplegable. También puede modificar esto para la tecla enter:

 window.addEventListener('click', function(e) { const dropDownWrapper = document.querySelector('#id of dropdown wrapper'); const path = e.path || (e.composedPath && e.composedPath()); if (!path.some(x => !(x instanceof SVGElement) && x.id && x.id === '#id of dropdown wrapper')) { dropDownWrapper.querySelector('.class of dropdownlist') ? x.querySelector('.class of dropdownlist').style.display = 'none' : null } else{ dropDownWrapper.querySelector('.class of dropdownlist') ? x.querySelector('.class of dropdownlist').style.display = 'block' : null } }, true);
almost 4 years ago · Juan Pablo Isaza Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2026 PeakU Inc. All Rights Reserved.
Andres GPT
Recomiéndame algunas ofertas
Necesito ayuda