gpt4 book ai didi

javascript - 通过javascript模拟键盘事件

转载 作者:数据小太阳 更新时间:2023-10-29 03:54:19 30 4
gpt4 key购买 nike

我正在尝试通过 javascript 在网页中模拟键盘事件,因为 Safari 浏览器不支持 Actions。

首先,我创建了一个简单的表单(如下所示)并尝试在文本框中切换,但没有成功。

使用的 Java 脚本:(ubuntu 和 chrome 浏览器)。我在 chrome 浏览器控制台中触发了脚本。

var pressTabKey = document.createEvent("KeyboardEvent");
pressTabKey.initKeyboardEvent("keypress", true, true, null, false, false, false, false, 9, 0);
document.getElementById('1234').focus();
document.getElementById('1234').dispatchEvent(pressTabKey);

HTML 格式:

   <html>      
<head>
</head>
<body>
<p>Test Page </p>
<form>
<input id="1234" type="text" value="Enter Here">
<br>
<br>
<input id="1235" type="text" value="Enter Here">
</form>
</body>
</html>

最佳答案

希望对您有所帮助:

https://developer.mozilla.org/en-US/docs/Web/Guide/Events/Creating_and_triggering_events

例子:我创建了一个事件并使用 dispatchEvent() 来触发它:

var pressTabKey = new Event('keydown');
document.getElementById('1234').addEventListener('keydown', function() { alert("hi!"); });
document.getElementById('1234').dispatchEvent(pressTabKey);

函数 createEvent() 已弃用: https://developer.mozilla.org/en-US/docs/Web/API/Document/createEvent


编辑:您可以简单地从 keydown 或 keypress 事件中读取键代码,如下所示:

http://jsfiddle.net/adrielD/me9q1qu6/

HTML

<p>Test Page </p>      
<form>
<input id="1234" type="text" value="Enter Here"><br>
<input id="1235" type="text" value="Enter Here">
</form>

JS:

var tab1 = document.getElementById("1234");
var tab2 = document.getElementById("1235");

tab1.addEventListener("keydown", function(event) {
if(event.keyCode == 9) {
event.preventDefault();
tab2.focus();
}
});

tab2.addEventListener("keydown", function(event) {
if(event.keyCode == 9) {
event.preventDefault();
tab1.focus();
}
});

关于javascript - 通过javascript模拟键盘事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32547586/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com