Запустить событие нажатия клавиш /keydown/keyup в JS/jQuery?

Как лучше всего имитировать ввод текста пользователем в поле ввода текста в JS и/или jQuery?

Я не хочу на самом деле помещать текст в поле ввода, я просто хочу вызвать все обработчики событий handlers, которые обычно запускаются пользователем, вводящим информацию в поле ввода. Это означает фокусировку, нажатие клавиш, нажатие клавиш, нажатие клавиш и размытие. думаю.

Так как же это сделать?

Ответ 1

Вы можете вызвать любое из событий с прямым вызовом к ним, например:

$(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.

Ответ 2

Вы можете отправлять события, такие как

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

Ответ 3

Чтобы вызвать нажатие enter, мне пришлось изменить ответ @ebynum, в частности, используя свойство keyCode.

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

Ответ 4

Вот пример ванильного 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);
    }
}

Ответ 5

Теперь вы можете сделать:

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

Ответ 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" />

Ответ 7

Прежде всего, мне нужно сказать, что образец из 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

Ответ 8

Я подумал, что хочу обратить ваше внимание на то, что в определенном контексте, где слушатель был определен в плагине jQuery, единственное, что успешно имитировало для меня событие нажатия клавиши, которое в конечном итоге было поймано этим слушателем, было использование setTimeout(). например

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

Любое использование $("#txtName").keypress() игнорировалось, хотя помещалось в конце функции .ready() function. Никакого конкретного дополнения DOM в любом случае не создавалось асинхронно.

Ответ 9

Для приведения типов к KeyboardEventInit и предоставления правильного целого числа keyCode

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