Я хотел бы узнать, какой символ ключа нажат в кросс-браузерном режиме в чистом javascript.
Как узнать, какая клавиша нажата?
Ответ 1
"Очистить" JavaScript:
<script type="text/javascript">
function myKeyPress(e){
var keynum;
if(window.event) { // IE
keynum = e.keyCode;
} else if(e.which){ // Netscape/Firefox/Opera
keynum = e.which;
}
alert(String.fromCharCode(keynum));
}
</script>
<form>
<input type="text" onkeypress="return myKeyPress(event)" />
</form>
JQuery
$(document).keypress(function(event){
alert(String.fromCharCode(event.which));
});
Ответ 2
Здесь миллион дубликатов этого вопроса, но здесь все равно повторяется:
document.onkeypress = function(evt) {
evt = evt || window.event;
var charCode = evt.keyCode || evt.which;
var charStr = String.fromCharCode(charCode);
alert(charStr);
};
Лучшая ссылка на ключевые события, которые я видел, - http://unixpapa.com/js/key.html.
Ответ 3
Чтобы обеспечить надежную кросс-браузерную поддержку, использовать библиотеку, например jQuery: см. события клавиатуры
Конечно, есть и другие библиотеки Javascript:
Ответ 4
Взгляните на этот сайт для непоследовательности кросс-браузера http://www.quirksmode.org/js/keys.html
Ответ 5
**check this out**
<!DOCTYPE html>
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<script>
$(document).ready(function(){
$(document).keypress(function(e)
{
var keynum;
if(window.event)
{ // IE
keynum = e.keyCode;
}
else if(e.which)
{
// Netscape/Firefox/Opera
keynum = e.which;
}
alert(String.fromCharCode(keynum));
var unicode=e.keyCode? e.keyCode : e.charCode;
alert(unicode);
});
});
</script>
</head>
<body>
<input type="text"></input>
</body>
</html>
Ответ 6
Одна из моих любимых библиотек для этого сложным способом - Mousetrap.
Он поставляется с множеством плагинов, одним из которых является плагин record
, который может идентифицировать последовательность нажатых клавиш.
Пример:
<script>
function recordSequence() {
Mousetrap.record(function(sequence) {
// sequence is an array like ['ctrl+k', 'c']
alert('You pressed: ' + sequence.join(' '));
});
}
</script>
<button onclick="recordSequence()">Record</button>
Ответ 7
Используйте это:
function onKeyPress(evt){
evt = (evt) ? evt : (window.event) ? event : null;
if (evt)
{
var charCode = (evt.charCode) ? evt.charCode :((evt.keyCode) ? evt.keyCode :((evt.which) ? evt.which : 0));
if (charCode == 13)
alert('User pressed Enter');
}
}
Ответ 8
Более свежий и намного более чистый: используйте event.key
. Нет никаких произвольных номеров!
node.addEventListener('keydown', function(event) {
const key = event.key; // "a", "1", "Shift", etc.
});