Я делаю простую текстовую игру OOP на основе javascript, в которой используется замена строк и корректировка переменных, привязанная к событиям кнопки .onclick. Меня попросили добавить горячие клавиши для более легкого доступа, и я не мог понять, как это сделать.
Сначала я попытался использовать сценарий горячих клавиш JSQuery и команду .bind, но мне показалось, что это займет очень много времени, так как мне придется перекодировать каждый .onclick как горячую клавишу, и даже с unbind он запускал каждое связанное событие. к ключу на скрипте.
Я чувствую, что лучший способ сделать это было бы, если бы я мог закодировать клавиши для графического интерфейса, т.е. если бы, когда вы нажали «1», он активировал .onclick кнопки 1, таким образом, горячая клавиша была бы статической (за исключением случаев, когда кнопка отключено), но я понятия не имею, как это сделать. Я только что использовал html-кнопки (например, input type="button" value="" disabled="disabled" id="button1"), я подозреваю, что мне нужно что-то более сложное?
Заранее спасибо за помощь, гугл бесполезен.
[EDIT - Общее описание кода]
Игра работает очень просто, через вызов функций как новых событий с другим текстом/кнопками (и разными событиями при нажатии, привязанными к этим кнопкам). Например, код начального экрана:
function startScreen() {
$(document).ready(function () {
$('#text').html("Game title and info");
$('#button1').val("Start Game");
$('#button1').attr("disabled", false);
$("#button1").one("click", function () {
textClear();
buttonClear();
nameScreen();
});
$("#button2").val("Load Game");
$('#button2').attr("disabled", false);
$("#button2").one("click", function () {
textClear();
buttonClear();
loadData();
});
$("#button6").val("Settings");
$('#button6').attr("disabled", false);
$("#button6").one("click", function () {
textClear();
buttonClear();
settingsScreen();
});
});
}
Поскольку код, выполняемый первой кнопкой, меняется между функциями, то, что делает горячая клавиша, была моей проблемой с использованием кода библиотеки JQuery.