Определенный способ для запуска событий нажатия клавиш с помощью jQuery - PullRequest
245 голосов
/ 07 мая 2009

Я прочитал все ответы на эти вопросы, и ни одно из решений, похоже, не работает.

Кроме того, я чувствую, что нажатие клавиш с помощью специальных символов не работает вообще. Может кто-нибудь проверить, кто это сделал?

Ответы [ 10 ]

347 голосов
/ 07 мая 2009

Если вы хотите вызвать событие нажатия клавиши или нажатия клавиши, все, что вам нужно сделать, это:

var e = jQuery.Event("keydown");
e.which = 50; // # Some key code value
$("input").trigger(e);
78 голосов
/ 28 октября 2011

Чуть более лаконично с jQuery 1.6 + :

var e = jQuery.Event( 'keydown', { which: $.ui.keyCode.ENTER } );

$('input').trigger(e);

(Если вы не используете jQuery UI, вместо этого введите соответствующий код клавиши.)

68 голосов
/ 01 января 2012

Реальный ответ должен включать keyCode:

var e = jQuery.Event("keydown");
e.which = 50; // # Some key code value
e.keyCode = 50
$("input").trigger(e);

Несмотря на то, что на веб-сайте jQuery написано, что и keyCode нормализованы, они очень сильно ошибаются. Всегда безопаснее выполнять стандартные кросс-браузерные проверки для e.which и e.keyCode, и в этом случае просто определить оба.

17 голосов
/ 30 июля 2010

Если вы также используете jQuery UI, вы можете сделать это так:

var e = jQuery.Event("keypress");
e.keyCode = $.ui.keyCode.ENTER;
$("input").trigger(e);
5 голосов
/ 15 мая 2015

Я заставил его работать с keyup.

$("#id input").trigger('keyup');
4 голосов
/ 15 декабря 2010

Хорошо, для меня это работает ...

var e2key = function(e) {
    if (!e) return '';
    var event2key = {
        '96':'0', '97':'1', '98':'2', '99':'3', '100':'4', '101':'5', '102':'6', '103':'7', '104':'8', '105':'9', // Chiffres clavier num
        '48':'m0', '49':'m1', '50':'m2', '51':'m3', '52':'m4', '53':'m5', '54':'m6', '55':'m7', '56':'m8', '57':'m9', // Chiffres caracteres speciaux
        '65':'a', '66':'b', '67':'c', '68':'d', '69':'e', '70':'f', '71':'g', '72':'h', '73':'i', '74':'j', '75':'k', '76':'l', '77':'m', '78':'n', '79':'o', '80':'p', '81':'q', '82':'r', '83':'s', '84':'t', '85':'u', '86':'v', '87':'w', '88':'x', '89':'y', '90':'z', // Alphabet
        '37':'left', '39':'right', '38':'up', '40':'down', '13':'enter', '27':'esc', '32':'space', '107':'+', '109':'-', '33':'pageUp', '34':'pageDown' // KEYCODES
    };
    return event2key[(e.which || e.keyCode)];
};

var page5Key = function(e, customKey) {
    if (e) e.preventDefault();
    switch(e2key(customKey || e)) {
        case 'left': /*...*/ break;
        case 'right': /*...*/ break;
    }
};

$(document).bind('keyup', page5Key);

$(document).trigger('keyup', [{preventDefault:function(){},keyCode:37}]); 
2 голосов
/ 17 октября 2017

Если вы хотите сделать это в одной строке, вы можете использовать

$("input").trigger(jQuery.Event('keydown', { which: '1'.charCodeAt(0) }));
2 голосов
/ 02 января 2016

это также может быть выполнено следующим образом ( документы )

$('input').trigger("keydown", {which: 50});
2 голосов
/ 04 февраля 2015

Если вам нужно учесть текущий курсор и выделение текста ...

Это не сработало для меня для приложения AngularJS на Chrome. Как указывает Надя в исходных комментариях, персонаж никогда не виден в поле ввода (по крайней мере, это был мой опыт). Кроме того, предыдущие решения не учитывают текущий выбор текста в поле ввода. Мне пришлось использовать замечательную библиотеку jquery-selection .

У меня есть настраиваемая экранная цифровая клавиатура, которая заполняет несколько полей ввода. Я должен был ...

  1. На фокусе, сохраните lastFocus.element
  2. При размытии сохранить текущий выделенный текст (запуск и остановка)

    var pos = element.selection('getPos')
    lastFocus.pos = { start: pos.start, end: pos.end}
    
  3. Когда нажата кнопка на моей клавиатуре:

    lastFocus.element.selection( 'setPos', lastFocus.pos)
    lastFocus.element.selection( 'replace', {text: myKeyPadChar, caret: 'end'})
    
1 голос
/ 27 апреля 2013

console.log( String.fromCharCode(event.charCode) );

Мне не нужно отображать персонажа.

...