Answers:
您可以通过直接调用事件来触发任何事件,如下所示:
$(function() {
$('item').keydown();
$('item').keypress();
$('item').keyup();
$('item').blur();
});
那会做你想做的事吗?
您可能还应该触发.focus()
并可能.change()
如果要使用特定键触发键事件,可以这样进行:
$(function() {
var e = $.Event('keypress');
e.which = 65; // Character 'A'
$('item').trigger(e);
});
这里有一些有关按键事件的有趣讨论:jQuery Event按键:按下了哪个键?,特别是与.where属性的跨浏览器兼容性。
ctrlKey: true
shiftKey
altKey
您可以调度类似的事件
el.dispatchEvent(new Event('focus'));
el.dispatchEvent(new KeyboardEvent('keypress',{'key':'a'}));
el.dispatchEvent(new Event('keypress', {keyCode: 'a'}))
Ctrl
: 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/巴勒斯坦/ 8d8J9
这是一个触发任何事件的普通js示例:
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);
}
}
您可以使用以下方法实现此目的: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" />
首先,我要说的是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
我想我会引起您的注意,在jQuery插件中定义了侦听器的特定上下文中,唯一成功地为我模拟了keypress事件并最终被该侦听器捕获的事情是使用setTimeout()。例如
setTimeout(function() { $("#txtName").keypress() } , 1000);
尽管放在末尾的任何使用都$("#txtName").keypress()
被忽略了.ready() function
。无论如何,没有异步创建特定的DOM补充。
$('item').trigger('keypress', {which: 'A'.charCodeAt(0)});