要在 Chrome 中模擬給定文字區域元素上的按鍵事件,您應該使用 initKeyboardEvent 方法。但是,您提供的初始代碼收到了不同的結果 - Enter 鍵碼,而不是預期的 m 鍵碼。
要修正此問題,您需要重寫 keyCode 和 KeyboardEvent 物件的 which 屬性。以下是更新後的程式碼:
<code class="javascript">var keyEvent = document.createEvent('KeyboardEvent'); // Override both keyCode and which 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);</code>
透過覆寫這兩個屬性,您可以確保瀏覽器收到正確的鍵碼值。此解決方案有效地模擬了指定按鍵的 keydown 事件,使您能夠實現所需的功能。
以上是如何在 Chrome 中正確指定按鍵模擬的按鍵代碼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!