Rumah >hujung hadapan web >tutorial js >Bagaimana untuk Mensimulasikan Peristiwa Keydown dengan betul dalam Chrome?

Bagaimana untuk Mensimulasikan Peristiwa Keydown dengan betul dalam Chrome?

Patricia Arquette
Patricia Arquetteasal
2024-10-18 13:22:02500semak imbas

How to Correctly Simulate Keydown Events in Chrome?

Simulasi Keydown dalam Chrome: Menetapkan Kekunci Ditekan Dengan Betul

Perihalan Masalah

Mensimulasikan peristiwa keydown pada kawasan teks dalam Chrome menggunakan initKeyboardEvent mengakibatkan kesilapan kunci sedang ditaip. Menetapkan KeyCode secara eksplisit gagal menyelesaikan isu.

Penyelesaian

Kunci untuk mensimulasikan peristiwa keydown dengan jayanya terletak pada mengatasi bukan sahaja sifat KeyCode tetapi juga sifat yang mana, seperti yang ditunjukkan di bawah:

<code class="js">document.addEventListener('keydown', e => console.log(
  'altKey                : ' + e.altKey + '\n' +
  'charCode (Deprecated) : ' + e.charCode + '\n' +
  'code                  : ' + e.code + '\n' +
  'ctrlKey               : ' + e.ctrlKey + '\n' +
  'isComposing           : ' + e.isComposing + '\n' +
  'key                   : ' + e.key + '\n' +
  'keyCode (Deprecated)  : ' + e.keyCode + '\n' +
  'location              : ' + e.location + '\n' +
  'metaKey               : ' + e.metaKey + '\n' +
  'repeat                : ' + e.repeat + '\n' +
  'shiftKey              : ' + e.shiftKey + '\n' +
  'which (Deprecated)    : ' + e.which + '\n' +
  'isTrusted             : ' + e.isTrusted + '\n' +
  'type                  : ' + e.type
));

Podium = {};
Podium.keydown = function(k) {
  var oEvent = document.createEvent('KeyboardEvent');

  // Chromium Hack
  Object.defineProperty(
    oEvent,
    'keyCode',
    {
       get : function() {
         return this.keyCodeVal;
       }
    }
  );
  Object.defineProperty(
    oEvent,
    'which',
    {
       get : function() {
         return this.keyCodeVal;
       }
    }
  );

  if (oEvent.initKeyboardEvent) {
    oEvent.initKeyboardEvent("keydown", true, true, document.defaultView,
                             false, false, false, false, k, k);
  }
  else {
      oEvent.initKeyEvent("keydown", true, true, document.defaultView,
                          false, false, false, false, k, 0);
  }

  oEvent.keyCodeVal = k;

  if (oEvent.keyCode !== k) {
    alert("keyCode mismatch " + oEvent.keyCode + "(" + oEvent.which + ")");
  }

  document.dispatchEvent(oEvent);
}

//Sample usage
Podium.keydown(65);</code>

Atas ialah kandungan terperinci Bagaimana untuk Mensimulasikan Peristiwa Keydown dengan betul dalam Chrome?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn