• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
    • Preguntas
    • Profesores
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Pruebas Online
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

124
Vistas
¿Actualizar evento de puntero (desplazamiento, desplazamiento, etc.) sin movimiento del mouse?

Dados dos divs a y b superpuestos: cambiar la propiedad de "eventos de puntero" de a (div superior) a "ninguno" no permitirá que el evento del mouse pase a div b (abajo). El cambio solo tiene efecto cuando el cursor se mueve un poco.

¿Cómo se puede hacer que este cambio sea instantáneo, sin que el usuario tenga que mover el mouse?

Pasos para la replicación de problemas usando un efecto de desplazamiento:

  1. Abre el Codepen
  2. recargar la pagina
  3. Inmediatamente coloque el cursor en el cuadro rojo y no mueva el mouse.
  4. Después de 3 segundos, se producen los cambios y el cuadro rojo se volverá morado. Pero hasta que el mouse se mueva un poco, no habrá ninguna actualización en el cursor CSS del cuadro azul a continuación.

HTML:

 <div class="a"></div> <div class="b"></div>

CSS:

 .a { top: 0; position: absolute; height: 30px; width: 30px; background: red; z-index: 1; } .b { top: 0; position: absolute; height: 50px; width: 50px; background: blue; } .b:hover { background: green; }

JS:

 delay(3000).then(() => { let a = document.getElementsByClassName("a")[0]; a.style["pointer-events"] = "none"; // < this updating is the problem a.style["background"] = "rgba(255,0,0,.5)"; // purely visual }); // delay function function delay(time) { return new Promise(resolve => setTimeout(resolve, time)); }
almost 3 years ago · Juan Pablo Isaza
1 Respuestas
Responde la pregunta

0

Para lograr esto, desea que el navegador vuelva a renderizar la escena. Hay muchas maneras de hacer esto, por ejemplo, agregando o eliminando elementos.

Un ejemplo es el siguiente: agregué un div "c" que no hace nada, pero después de cambiar los eventos de puntero en "a", llamo a setTimeout (sin milisegundos, por lo que es el siguiente cuadro) cuando el fondo es configurado, y la visualización de "c" se configura en ninguno. Esto hace que toda la escena se vuelva a dibujar y obtienes el valor de desplazamiento en "b" que deseas.

 delay(3000).then(() => { let a = document.getElementsByClassName("a")[0]; a.style["pointer-events"] = "none"; // < this updating is the problem // this is just to show that it could be any div that you do do this to let c = document.getElementsByClassName("c")[0]; setTimeout(() => { a.style["background"] = "rgba(255,0,0,.5)"; // purely visual c.style.display = "none"; }); }); // delay function function delay(time) { return new Promise(resolve => setTimeout(resolve, time)); }
 .a { top: 0; position: absolute; height: 30px; width: 30px; background: red; z-index: 1; } .b { top: 0; position: absolute; height: 50px; width: 50px; background: blue; } .b:hover { background: green; }
 <div class="a"></div> <div class="b"></div> <div class="c"></div>

almost 3 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
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda