触发JS / jQuery中的keypress / keydown / keyup事件?


173

模拟用户在JS和/或jQuery中的文本输入框中输入文本的最佳方法是什么?

希望居然把文本输入框,我只是想触发所有的事件处理程序,通常会得到用户输入信息到一个输入框触发。这意味着聚焦,按下键,按下键,按下键和模糊。我认为。

那么,一个人如何做到这一点呢?

Answers:


240

您可以通过直接调用事件来触发任何事件,如下所示:

$(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属性的跨浏览器兼容性。


3
$('item').trigger('keypress', {which: 'A'.charCodeAt(0)});
Bob Stein

@ebynum可以用Javascript写一些代码(没有jquery)。
克里斯·P

1
如果您需要Ctrl ctrlKey: trueshiftKeyaltKey
:,

50

您可以调度类似的事件

el.dispatchEvent(new Event('focus'));
el.dispatchEvent(new KeyboardEvent('keypress',{'key':'a'}));

5
el.dispatchEvent(new Event('keypress', {keyCode: 'a'}))
Cuzox

1
@Cuzox为什么不使用KeyboardEvent?它会自动填充shiftKey等值,这是正确的方法。另外,您在keyCode中放置了一个字符串,这是错误的。
SuperOP535

6
如果您需要Ctrlel.dispatchEvent(new KeyboardEvent('keydown', { keyCode: 70, ctrlKey: true }));(这将导致一个快捷方式Ctrl + F
ИльяЗеленько

31

要触发enter按键,我必须修改@ebynum响应,特别是使用keyCode属性。

e = $.Event('keyup');
e.keyCode= 13; // enter
$('input').trigger(e);

2
keydown事件没有被捕获,或者我在这里做错了什么?fiddle.jshell.net/巴勒斯坦/ 8d8J9
Omar,0:

@cloak:有效。在这里查看我的评论,以获取用于修复asp.net控件的完整选择器:codeproject.com/Tips/269388/…如果使用Ajax,请确保在dom中插入任何内容后调用它。
丹·伦道夫

23

这是一个触发任何事件的普通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);
    }
}

7
您能否提供一些用法示例?您的函数将如何用于发送键码?
Mac Mac

6
可以在以下包含文档的链接中找到该帖子的源代码:plainjs.com/javascript/events/trigger-an-event-11
Kieren Dixon

17

您可以使用以下方法实现此目的: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" />

MDN dispatchEvent

MDN KeyboardEvent


12

您现在可以执行以下操作:

var e = $.Event("keydown", {keyCode: 64});

2

首先,我要说的是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

1

我想我会引起您的注意,在jQuery插件中定义了侦听器的特定上下文中,唯一成功地为我模拟了keypress事件并最终被该侦听器捕获的事情是使用setTimeout()。例如

setTimeout(function() { $("#txtName").keypress() } , 1000);

尽管放在末尾的任何使用都$("#txtName").keypress()忽略.ready() function。无论如何,没有异步创建特定的DOM补充。


1

对于打字稿强制转换为KeyboardEventInit并提供正确的keyCode整数

const event = new KeyboardEvent("keydown", {
          keyCode: 38,
        } as KeyboardEventInit);

1
@CamiRodriguez在TypeScript中可以执行的任何操作都可以在JS中实现(就像jQuery一样)。除了TypeScript不会弄乱JS语法外,只是对其进行扩展。如果您将`删除为KeyboardEventInit`,则基本上是JS代码。+1的答案,谢谢。
Gergő霍瓦特
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.