如何检测何时按下其中一个箭头键?我用这个来找出:
function checkKey(e) {
var event = window.event ? window.event : e;
console.log(event.keyCode)
}
虽然它适用于所有其他键,但它没有用于箭头键(可能因为默认情况下浏览器应该在这些键上滚动)。
答案 0 :(得分:634)
箭头键仅由onkeydown
触发,而不是onkeypress
密钥代码是:
答案 1 :(得分:202)
按键上下通话功能。每个密钥都有不同的代码。
document.onkeydown = checkKey;
function checkKey(e) {
e = e || window.event;
if (e.keyCode == '38') {
// up arrow
}
else if (e.keyCode == '40') {
// down arrow
}
else if (e.keyCode == '37') {
// left arrow
}
else if (e.keyCode == '39') {
// right arrow
}
}
答案 2 :(得分:89)
可能是最简洁的表述:
document.onkeydown = function(e) {
switch (e.keyCode) {
case 37:
alert('left');
break;
case 38:
alert('up');
break;
case 39:
alert('right');
break;
case 40:
alert('down');
break;
}
};
演示(感谢用户Angus Grant):http://jsfiddle.net/angusgrant/E3tE6/
这应该跨浏览器工作。如果浏览器不起作用,请发表评论。
还有其他方法可以获取密钥代码(例如,e.charCode和window.event而不是e),但它们不是必需的。您可以在http://www.asquare.net/javascript/tests/KeyCode.html尝试大部分内容。 请注意,event.keycode在Firefox中不能与onkeypress一起使用,但它可以与onkeydown一起使用。
答案 3 :(得分:58)
更新,更清洁:使用event.key
。没有更多的任意数字代码!如果您正在翻译或知道您的用户都在现代浏览器上,请使用此功能!
node.addEventListener('keydown', function(event) {
const key = event.key; // "ArrowRight", "ArrowLeft", "ArrowUp", or "ArrowDown"
});
详细处理:
switch (event.key) {
case "ArrowLeft":
// Left pressed
break;
case "ArrowRight":
// Right pressed
break;
case "ArrowUp":
// Up pressed
break;
case "ArrowDown":
// Down pressed
break;
}
您可以轻松扩展此项以检查"w", "a", "s", "d"
或任何其他键
P.S。 event.code
与箭头的 相同
答案 4 :(得分:19)
使用keydown
,而不是keypress
用于不可打印的键,例如箭头键:
function checkKey(e) {
e = e || window.event;
alert(e.keyCode);
}
document.onkeydown = checkKey;
我发现的最好的JavaScript关键事件参考(例如,在quirksmode上击败裤子)就在这里:http://unixpapa.com/js/key.html
答案 5 :(得分:11)
document.onkeydown = function (e) {
switch (e.key) {
case 'ArrowUp':
// up arrow
break;
case 'ArrowDown':
// down arrow
break;
case 'ArrowLeft':
// left arrow
break;
case 'ArrowRight':
// right arrow
}
};
答案 6 :(得分:8)
function checkArrowKeys(e){
var arrs= ['left', 'up', 'right', 'down'],
key= window.event? event.keyCode: e.keyCode;
if(key && key>36 && key<41) alert(arrs[key-37]);
}
document.onkeydown= checkArrowKeys;
答案 7 :(得分:8)
以下是一个示例实现:
var targetElement = $0 || document.body;
function getArrowKeyDirection (keyCode) {
return {
37: 'left',
39: 'right',
38: 'up',
40: 'down'
}[keyCode];
}
function isArrowKey (keyCode) {
return !!getArrowKeyDirection(keyCode);
}
targetElement.addEventListener('keydown', function (event) {
var direction,
keyCode = event.keyCode;
if (isArrowKey(keyCode)) {
direction = getArrowKeyDirection(keyCode);
console.log(direction);
}
});
答案 8 :(得分:7)
以下是我的表现:
nil
答案 9 :(得分:6)
我已经能够用jQuery捕获它们了:
$(document).keypress(function (eventObject) {
alert(eventObject.keyCode);
});
答案 10 :(得分:4)
这是chrome和firefox的工作代码
<html>
<head>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.1/jquery.min.js"></script>
<script type="text/javascript">
function leftArrowPressed() {
alert("leftArrowPressed" );
window.location = prevUrl
}
function rightArrowPressed() {
alert("rightArrowPressed" );
window.location = nextUrl
}
function topArrowPressed() {
alert("topArrowPressed" );
window.location = prevUrl
}
function downArrowPressed() {
alert("downArrowPressed" );
window.location = nextUrl
}
document.onkeydown = function(evt) {
var nextPage = $("#next_page_link")
var prevPage = $("#previous_page_link")
nextUrl = nextPage.attr("href")
prevUrl = prevPage.attr("href")
evt = evt || window.event;
switch (evt.keyCode) {
case 37:
leftArrowPressed(nextUrl);
break;
case 38:
topArrowPressed(nextUrl);
break;
case 39:
rightArrowPressed(prevUrl);
break;
case 40:
downArrowPressed(prevUrl);
break;
}
};
</script>
</head>
<body>
<p>
<a id="previous_page_link" href="http://www.latest-tutorial.com">Latest Tutorials</a>
<a id="next_page_link" href="http://www.zeeshanakhter.com">Zeeshan Akhter</a>
</p>
</body>
</html>
答案 11 :(得分:3)
那个更短。
function IsArrows (e) {
return (e.keyCode >= 37 && e.keyCode <= 40);
}
答案 12 :(得分:3)
在我看到这篇文章之前,我也在寻找这个答案。
我找到了另一个解决方案来了解不同密钥的密钥代码,礼貌地解决了我的问题。我只是想分享我的解决方案。
使用keyup / keydown事件使用event.keyCode
在控制台/警报中写入相同的值。像 -
console.log(event.keyCode)
// or
alert(event.keyCode)
- rupam
答案 13 :(得分:2)
您需要keydown
而非keypress
的答案。
假设您想在按下键的同时连续移动某些内容,我发现keydown
适用于除Opera以外的所有浏览器。对于Opera,keydown
仅在第一次按下时触发。为了适应Opera的使用:
document.onkeydown = checkKey;
document.onkeypress = checkKey;
function checkKey(e)
{ etc etc
答案 14 :(得分:2)
这个图书馆摇滚! https://craig.is/killing/mice
Mousetrap.bind('up up down down left right left right b a enter', function() {
highlight([21, 22, 23]);
});
您需要快速按下序列以突出显示该页面中的代码。
答案 15 :(得分:2)
箭头键在 keyup
上触发$(document).on("keyup", "body", function(e) {
if (e.keyCode == 38) {
// up arrow
console.log("up arrow")
}
if (e.keyCode == 40) {
// down arrow
console.log("down arrow")
}
if (e.keyCode == 37) {
// left arrow
console.log("lefy arrow")
}
if (e.keyCode == 39) {
// right arrow
console.log("right arrow")
}
})
onkeydown允许ctrl,alt,拉屎
onkeyup允许使用制表符,向上箭头,向下箭头,向左箭头,向下箭头
答案 16 :(得分:1)
我相信最新的方法是:
document.addEventListener("keydown", function(event) {
event.preventDefault();
const key = event.key; // "ArrowRight", "ArrowLeft", "ArrowUp", or "ArrowDown"
switch (key) { // change to event.key to key to use the above variable
case "ArrowLeft":
// Left pressed
<do something>
break;
case "ArrowRight":
// Right pressed
<do something>
break;
case "ArrowUp":
// Up pressed
<do something>
break;
case "ArrowDown":
// Down pressed
<do something>
break;
}
});
这假定开发人员希望代码在页面上的任何位置都处于活动状态,并且客户端应忽略任何其他按键。消除event.preventDefault();如果按键(包括此处理程序捕获的按键)仍应处于活动状态,则为行。
答案 17 :(得分:1)
如果您使用jquery,那么您也可以这样做,
$(document).on("keydown", '.class_name', function (event) {
if (event.keyCode == 37) {
console.log('left arrow pressed');
}
if (event.keyCode == 38) {
console.log('up arrow pressed');
}
if (event.keyCode == 39) {
console.log('right arrow pressed');
}
if (event.keyCode == 40) {
console.log('down arrow pressed');
}
});
答案 18 :(得分:1)
使用key和ES6。
这为您提供了每个箭头键的单独功能,而无需使用开关,并且在NumLock
处于打开状态时,也可以与数字键盘中的2、4、6、8键一起使用。
const element = document.querySelector("textarea"),
ArrowRight = k => {
console.log(k);
},
ArrowLeft = k => {
console.log(k);
},
ArrowUp = k => {
console.log(k);
},
ArrowDown = k => {
console.log(k);
},
handler = {
ArrowRight,
ArrowLeft,
ArrowUp,
ArrowDown
};
element.addEventListener("keydown", e => {
const k = e.key;
if (handler.hasOwnProperty(k)) {
handler[k](k);
}
});
<p>Click the textarea then try the arrows</p>
<textarea></textarea>
答案 19 :(得分:0)
控制关键代码%=37
和&=38
...仅左箭头键= 37 up = 38
function IsArrows (e) {
return ( !evt.shiftKey && (e.keyCode >= 37 && e.keyCode <= 40));
}
答案 20 :(得分:0)
如果要检测箭头按键,但不需要使用Java脚本
function checkKey(e) {
if (e.keyCode !== 38 || e.keyCode !== 40 || e.keyCode !== 37 || e.keyCode !== 39){
// do something
};
}