Я нашел ответ на свой вопрос.Мне действительно не нравится решение, потому что оно немного грязное, и я не знаю, является ли оно пуленепробиваемым.Любая идея по этому вопросу будет принята с благодарностью, и если здесь будет использован внешний подход, он будет немного более чистым.
var altgr = false;
$(document).on("keyup", function (event) {
if((event.key === "AltGraph"|| event.key ==="Alt")||(event.ctrlKey && event.altKey)){
altgr=false;
}
});
$(document).on("keydown", function(event)
{
var altkey = event.key;
if((event.key === "AltGraph")||(event.ctrlKey && event.altKey)){
altgr = true;
}
console.log(altgr);
// AltGr+Q
if(event.which === 81 && altgr)
{
$("#notes").empty('');
$("#notes").append("Success!<br/>" , " Event: ", event.which, " ctrlKey: ", event.ctrlKey, " Altkey: ", event.altKey);
return false;
}
if(event.which === 87 && altgr)
{
$("#notes").empty('');
$("#notes").append("Success!<br/>" , " Event: ", event.which, " ctrlKey: ", event.ctrlKey, " Altkey: ", event.altKey);
return false;
}
else
{
$("#notes").empty('');
$("#notes").append("Fail! <br/>" , " Event: ", event.which, " ctrlKey: ", event.ctrlKey, " Altkey: ", event.altKey);
return false;
}
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div>
<span id="notes">Click to focus snippet and test keydown event, works well in Explorer/Edge but not in chrome</span>
<div/>