Wie finde ich heraus, welche Zeichentaste gedrückt wird?

118

Ich möchte herausfinden, welche Zeichentaste browserübergreifend in reinem Javascript gedrückt wird.

xXx
quelle
1
Sind nicht alle diese Antworten auf die Frage "Welche Taste wurde gedrückt?" Was ist, wenn Javascript-Code während der Ausführung wissen möchte, ob eine Taste auf der Tastatur gerade gedrückt gehalten wird?
Mwardm
2
event.keywird Ihnen direkt den gepressten Saibling geben
Gibolt

Antworten:

158

JavaScript "löschen":

<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)); 
});
Coyod
quelle
6
Dies funktioniert gut für alphabetische Zeichen, aber was ist mit Punkten / Klammern und anderen typografischen Symbolen?
VoVaVc
6
@VoVaVc: Es funktioniert auch für diese. Entscheidend ist , mit der keypressVeranstaltung, die Sie einen Zeichencode gibt, anstatt keyupoder keydownwelche geben Sie einen Schlüsselcode.
Tim Down
2
@aljgom, hat e.keynoch keine vollständige Browserunterstützung.
Andy Mercer
1
Funktioniert nicht für Symbole, für deren Erstellung Sie die Umschalttaste drücken müssen, z.
Curtis
5
@ AndyMercer Key wird jetzt von allen gängigen Browsern unterstützt: developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/…
Ray
34

Es gibt hier eine Million Duplikate dieser Frage, aber hier geht es trotzdem noch einmal:

document.onkeypress = function(evt) {
    evt = evt || window.event;
    var charCode = evt.keyCode || evt.which;
    var charStr = String.fromCharCode(charCode);
    alert(charStr);
};

Die beste Referenz zu wichtigen Ereignissen, die ich gesehen habe, ist http://unixpapa.com/js/key.html .

Tim Down
quelle
23

Neuere und viel sauberere: verwenden event.key. Keine willkürlichen Nummerncodes mehr!

HINWEIS: Die alten Eigenschaften ( .keyCodeund .which) sind veraltet.

node.addEventListener('keydown', function(event) {
    const key = event.key; // "a", "1", "Shift", etc.
});

Wenn Sie sicherstellen möchten, dass nur einzelne Zeichen eingegeben werden, überprüfen Sie key.length === 1, ob es sich um eines der erwarteten Zeichen handelt.

Mozilla Docs

Unterstützte Browser

Gibolt
quelle
Ist das für node.js?
Merrybot
Nein, Knoten bedeutet nur ein beliebiges DOM-Element. Wenn Sie Node.js mit einer Benutzeroberfläche verbinden würden, würde es
wahrscheinlich
Keydown für einige mobile Geräte funktioniert nicht, es wird undefiniert zurückgegeben
Angelotti
4

Versuchen:

<table>
<tr><td>Key:</td><td id="key"></td></tr>
<tr><td>Key Code:</td><td id="keyCode"></td></tr>
<tr><td>Event Code:</td><td id="eventCode"></td></tr>
</table>
<script type="text/javascript">
window.addEventListener("keydown", function (e) {
  //tested in IE/Chrome/Firefox
  document.getElementById("key").innerHTML = e.key;
  document.getElementById("keyCode").innerHTML = e.keyCode;
  document.getElementById("eventCode").innerHTML = e.code;
})
</script>

* Hinweis: Dies funktioniert in "Code-Snippet ausführen".

Diese Website macht dasselbe wie mein Code oben: Keycode.info

lewdev
quelle
1

Verwende das hier:

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');
  }
}
JCasso
quelle
1
**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>
kki3908050
quelle
1
Ist das nicht ein nahezu genaues Duplikat der Antwort von @ Coyod aus dem Jahr 2009?
Chris F Carroll
1

Eine meiner Lieblingsbibliotheken, um dies auf raffinierte Weise zu tun, ist Mausefalle .

Es ist mit einer Vielzahl von Plugins ausgestattet, von denen eines das recordPlugin ist, das eine Folge von gedrückten Tasten identifizieren kann.

Beispiel:

<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>
dipole_moment
quelle
@ DanLowe Ich habe gerade ein Snippet hinzugefügt.
dipole_moment
Ungefangener TypeError: Mousetrap.record ist keine Funktion bei recordSequence (****. Html: 12) bei HTMLButtonElement.onclick (****. Html: 20)
Irrmich
-2
document.onkeypress = function(event){
    alert(event.key)
}
Gomozor
quelle