Evitar el cierre del menú desplegable en clics internos
Para evitar que los menús desplegables de Twitter Bootstrap se cierren cuando se hace clic en un elemento interno, una solución que evita Se requiere el manejo del evento de clic delegado. Aquí hay una explicación detallada y una solución propuesta:
De forma predeterminada, los menús desplegables de Twitter Bootstrap se cierran al hacer clic, incluso dentro del propio menú. Para superar este comportamiento, un enfoque común implica adjuntar un controlador de eventos de clic al menú desplegable y llamar a event.stopPropagation() para evitar la propagación de eventos.
Sin embargo, para configuraciones que utilizan componentes como controles de carrusel, el evento delegado El mecanismo de manejo de Twitter Bootstrap puede interferir con el comportamiento previsto. En tales casos, hacer clic en estos controles puede no desencadenar la acción esperada debido a que el evento no llega a los controladores de eventos delegados.
Confiar en eventos ocultos/ocultos desplegables no es una alternativa viable ya que estos eventos carecen de información esencial y control sobre el contenido desplegable.
Solución propuesta
Una solución eficaz es utilizar la delegación de eventos en un elemento contenedor que alberga el menú desplegable. Aquí hay un ejemplo:
$(document).on('click', 'someyourContainer .dropdown-menu', function (e) {
e.stopPropagation();
});
En este ejemplo, al hacer clic en elementos dentro del contenedor especificado se seguirá propagando el evento a sus respectivos controladores delegados. Sin embargo, los clics específicamente en el menú desplegable serán interceptados y event.stopPropagation() evitará el comportamiento de cierre del menú desplegable.
Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.
Copyright© 2022 湘ICP备2022001581号-3