如何在JS和/或jQuery中模拟用户输入文本的最佳方法?
我不想实际放置文本在输入框中,我只想触发所有事件处理程序,这些事件通常会由用户在输入框中键入信息而触发。这包括焦点、keydown、keypress、keyup和blur。 我想。
那么,如何完成这个过程?
如何在JS和/或jQuery中模拟用户输入文本的最佳方法?
我不想实际放置文本在输入框中,我只想触发所有事件处理程序,这些事件通常会由用户在输入框中键入信息而触发。这包括焦点、keydown、keypress、keyup和blur。 我想。
那么,如何完成这个过程?
$(function() {
$('item').keydown();
$('item').keypress();
$('item').keyup();
$('item').blur();
});
那样做是否可以实现你想要的功能?
你还应该触发 .focus()
并且可能触发 .change()
如果你想使用特定的键来触发按键事件,可以这样做:
$(function() {
var e = $.Event('keypress');
e.which = 65; // Character 'A'
$('item').trigger(e);
});
这里有一些关于keypress
事件的有趣讨论:jQuery Event Keypress: Which key was pressed?,特别是与 .which
属性在跨浏览器兼容性方面的讨论。
您可以像这样分发事件:
el.dispatchEvent(new Event('focus'));
el.dispatchEvent(new KeyboardEvent('keypress',{'key':'a'}));
el.dispatchEvent(new Event('keypress', {keyCode: 'a'}))
- cuzoxCtrl
:
el.dispatchEvent(new KeyboardEvent('keydown', { keyCode: 70, ctrlKey: true }));
(这将触发快捷键 Ctrl + F
)。 - Илья Зеленько为了触发按下 enter 键,我不得不修改 @ebynum 的回答,具体来说,使用 keyCode 属性。
e = $.Event('keyup');
e.keyCode= 13; // enter
$('input').trigger(e);
keydown
事件没有被捕获,或者我在这里做错了什么吗?fiddle.jshell.net/Palestinian/8d8J9。 - Omar你可以通过以下方式实现:EventTarget.dispatchEvent(event)
,并将新的KeyboardEvent作为事件传递。
例如:element.dispatchEvent(new KeyboardEvent('keypress', {'key': 'a'}))
工作示例:
// get the element in question
const input = document.getElementsByTagName("input")[0];
// focus on the input element
input.focus();
// add event listeners to the input element
input.addEventListener('keypress', (event) => {
console.log("You have pressed key: ", event.key);
});
input.addEventListener('keydown', (event) => {
console.log(`key: ${event.key} has been pressed down`);
});
input.addEventListener('keyup', (event) => {
console.log(`key: ${event.key} has been released`);
});
// dispatch keyboard events
input.dispatchEvent(new KeyboardEvent('keypress', {'key':'h'}));
input.dispatchEvent(new KeyboardEvent('keydown', {'key':'e'}));
input.dispatchEvent(new KeyboardEvent('keyup', {'key':'y'}));
<input type="text" placeholder="foo" />
这里有一个使用原生 JavaScript 触发任何事件的例子:
function triggerEvent(el, type){
if ('createEvent' in document) {
// modern browsers, IE9+
var e = document.createEvent('HTMLEvents');
e.initEvent(type, false, true);
el.dispatchEvent(e);
} else {
// IE 8
var e = document.createEventObject();
e.eventType = type;
el.fireEvent('on'+e.eventType, e);
}
}
你现在可以做到:
var e = $.Event("keydown", {keyCode: 64});
首先,我需要说的是来自Sionnach733的示例完美无缺。一些用户抱怨缺少实际示例。这是我的意见。我一直在研究鼠标点击模拟,当使用这个网站时:https://www.youtube.com/tv。你可以打开任何视频并尝试运行此代码。它执行切换到下一个视频。
function triggerEvent(el, type, keyCode) {
if ('createEvent' in document) {
// modern browsers, IE9+
var e = document.createEvent('HTMLEvents');
e.keyCode = keyCode;
e.initEvent(type, false, true);
el.dispatchEvent(e);
} else {
// IE 8
var e = document.createEventObject();
e.keyCode = keyCode;
e.eventType = type;
el.fireEvent('on'+e.eventType, e);
}
}
var nextButton = document.getElementsByClassName('icon-player-next')[0];
triggerEvent(nextButton, 'keyup', 13); // simulate mouse/enter key press
对于 TypeScript,将其转换为 KeyboardEventInit 类型并提供正确的 keyCode 整数。
const event = new KeyboardEvent("keydown", {
keyCode: 38,
} as KeyboardEventInit);
我想提醒您,在jQuery插件中定义了一个监听器的特定情况下,唯一能够成功模拟按键事件并被该监听器捕获的方法是使用setTimeout()。
例如:setTimeout(function() { $("#txtName").keypress() } , 1000);
$("#txtName").keypress()
的使用都被忽略了,即使它被放置在.ready()函数
的末尾。无论如何也没有创建特定的DOM补充程序。
$('item').trigger('keypress', {which: 'A'.charCodeAt(0)});
的意思是触发一个键盘按键事件,其中按下的键为大写字母 A。 - Bob SteinctrlKey: true
,还有:shiftKey
,altKey
。 - Илья Зеленько