"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > ¿Cómo resolver la entrada de clave incorrecta durante la simulación de pulsación de tecla en Chrome?

¿Cómo resolver la entrada de clave incorrecta durante la simulación de pulsación de tecla en Chrome?

Publicado el 2024-11-03
Navegar:925

How to Resolve Incorrect Key Input During Keydown Simulation in Chrome?

Simulación de pulsación de tecla en Chrome: solución de problemas de entrada de clave incorrecta

En una aplicación web creada con Chrome, la simulación de un evento de pulsación de tecla en un elemento de área de texto puede presentar desafíos. A pesar de intentar especificar un código de clave específico, el área de texto puede recibir un valor de clave incorrecto, como la tecla Intro en lugar de la clave deseada.

Para resolver este problema, puede emplear un código personalizado que anule tanto el " keyCode' y las propiedades 'what' en el objeto 'KeyboardEvent'. 'keyCode' es una propiedad heredada que ha quedado obsoleta en favor de 'cuál'. Chrome se comporta de manera diferente con estas propiedades:

  • Solo es necesario anular 'keyCode' en Firefox o Safari.
  • En Chrome, debes anular tanto 'keyCode' como 'cuál'.

El siguiente código proporciona un ejemplo de cómo simular un evento de pulsación de tecla con el valor "cuál" correcto en Chrome:

var keyEvent = document.createEvent('KeyboardEvent');

// Override 'keyCode' and 'which' properties
Object.defineProperty(keyEvent, 'keyCode', { get: function() { return this.keyCodeVal; } });
Object.defineProperty(keyEvent, 'which', { get: function() { return this.keyCodeVal; } });

keyEvent.initKeyboardEvent('keydown', true, false, null, 0, false, 0, false, 77, 0);
keyEvent.keyCodeVal = 77;
inputNode.dispatchEvent(keyEvent);

Este código anula las propiedades 'keyCode' y 'what', lo que garantiza que Chrome interprete el evento correctamente y active el valor clave deseado (77) para la clave 'm'.

Declaración de liberación Este artículo se reimprime en: 1729225517 Si hay alguna infracción, comuníquese con [email protected] para eliminarla.
Último tutorial Más>

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