首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在JS/jQuery中触发keypress/keydown/keyup事件?

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

Stack Overflow用户
提问于 2010-07-30 11:43:42
回答 8查看 346.4K关注 0票数 196

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

我不想在输入框中输入文本,我只想触发所有的处理程序,这些处理程序通常是由用户在输入框中输入信息而触发的。这意味着焦点、快捷键和模糊。我认为。

那么如何做到这一点呢?

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2010-07-30 11:51:03

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

代码语言:javascript
复制
$(function() {
    $('item').keydown();
    $('item').keypress();
    $('item').keyup();
    $('item').blur();
});

这能做你想做的事吗?

您可能还应该触发.focus()和潜在的.change()

如果您想使用特定的key来触发key-events,可以这样做:

代码语言:javascript
复制
$(function() {
    var e = $.Event('keypress');
    e.which = 65; // Character 'A'
    $('item').trigger(e);
});

这里有一些关于按键事件的有趣讨论:jQuery Event Keypress: Which key was pressed?,特别是关于跨浏览器与.which属性的兼容性。

票数 259
EN

Stack Overflow用户

发布于 2017-04-09 02:59:30

您可以像这样调度事件

代码语言:javascript
复制
el.dispatchEvent(new Event('focus'));
el.dispatchEvent(new KeyboardEvent('keypress',{'key':'a'}));
票数 87
EN

Stack Overflow用户

发布于 2016-05-31 18:03:44

下面是一个普通的js示例,可以触发任何事件:

代码语言: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);
    }
}
票数 25
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3368578

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档