Comment détecter les touches du clavier ?
par
, 12/06/2017 à 10h45 (1712 Affichages)
Le 2014-01-22, j'ai écrit un Q/R jQuery : "Comment puis-je intercepter les frappes multitouches ?"
J'utilisais alors event.which, mais aujourd’hui c'est obsolète, et l'on doit utiliser event.key et ses valeurs prédéfinies.
Envoyé par Watilin; https://www.developpez.net/forums/d1708543/webmasters-developpement-web/javascript-ajax-typescript-dart/javascript/bonnes-manieres-detecter-touches-clavier/#post9356084Envoyé par Watilin; https://www.developpez.net/forums/d1708543/webmasters-developpement-web/javascript-ajax-typescript-dart/javascript/bonnes-manieres-detecter-touches-clavier/#post9357786Interception des frappes simples ou multiples (touches *, Ctrl+*, Shift+* et Ctrl+Shift+*), exemple :Envoyé par Watilin; https://www.developpez.net/forums/d1708543/webmasters-developpement-web/javascript-ajax-typescript-dart/javascript/bonnes-manieres-detecter-touches-clavier/#post9357861
Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part <input id="tapezIci" type="text" placeholder="tapez ici...">
Code JavaScript : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59 let boolControl = false, boolShift = false; const tapezIci = document.querySelector( "#tapezIci" ), keyboard = ev => { ev.preventDefault(); ev.stopPropagation(); // debug //console.log( ev.type, ev.key, boolControl, boolShift ); // utilisation switch( ev.key ){ case "F12" : console.log( "console, touche ", ev.key ); break; case "OS" : console.log( "touches META+d = ", ev.key ); break; case "â" : console.log( "dead ^ + a = ", ev.key ); break; case "z" : console.log( "touche ", ev.key ); if ( boolControl ){ console.log( "ctrl + z" ); } break; case "Z" : console.log( "touche ", ev.key ); if ( boolControl && boolShift ){ console.log( "ctrl + Shift + z" ); } break; default : console.log( "touche ", ev.key ); break; } // gestion des booléens switch ( ev.key ){ case "Control" : boolControl = true; break; case "Shift" : boolShift = true; break; default : boolControl = false; boolShift = false; break; } } tapezIci.addEventListener( "keydown", ev => { console.clear(); keyboard( ev ) }, false );