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

时间:2010-07-30 03:43:42

标签: javascript javascript-events jquery

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

想要在输入框中实际放置文字,我只是想触发通常由用户输入信息触发的所有事件处理程序输入框。这意味着焦点,keydown,按键,键盘和模糊。我认为。

那么如何实现这一目标呢?

9 个答案:

答案 0 :(得分:223)

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

$(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 Keypress: Which key was pressed?,特别是关于与.which属性的跨浏览器兼容性。

答案 1 :(得分:29)

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

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

答案 2 :(得分:28)

您可以调度

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

答案 3 :(得分:19)

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

答案 4 :(得分:10)

您现在可以:

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

答案 5 :(得分:6)

您可以使用: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" />
&#13;
&#13;
&#13;

MDN dispatchEvent

MDN KeyboardEvent

答案 6 :(得分: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

答案 7 :(得分:0)

我想我会引起你的注意,在一个jQuery插件中定义了一个监听器的特定环境中,那个成功模拟我的keypress事件,最终被该监听器捕获的事情就是使用setTimeout() 。 e.g。

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

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

答案 8 :(得分:0)

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

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