如何检测单个控制键盘事件而不是键组合?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何检测单个控制键盘事件而不是键组合?相关的知识,希望对你有一定的参考价值。
用它来检测control
关键事件很容易
document.addEventListener('keyup', handler, false);
...
function handler(e) {
var key = e.which || e.keyCode;
if (key == 17) { // Control key
...
}
}
问题是任何键组合,如control-c
和control-v
也会触发事件,似乎事件处理程序无法区分单个control
和control
中的control-c
。
我想要的是只允许一键按下并释放,而不是按键组合来触发事件。
答案
您实际上可以使用e.ctrlKey
和e.altKey
,根据这些键是否被按下,该值将为true或false。
在您的活动中,它将是这样的:
if (e.ctrlKey || e.altKey) {
return;
}
编辑
作为参考,您可以查看https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/ctrlKey。
此属性实际上是一个布尔值,它返回触发事件时是否按下了ctrl键。
然后,您可以看到,如果用户决定按下ctrl键而没有其他键,则此方法将不会返回,并且e.ctrlKey将为false,因为在触发keyUp事件时,用户已经释放了该键。
另一答案
这个怎么样:
var controlConsidered = false;
function ctrlPressed() {
console.log("Control was pressed.");
}
function keydownhandler(e) {
var key = e.which || e.keyCode;
controlConsidered = (key == 17);
}
function keyuphandler(e) {
var key = e.which || e.keyCode;
if (key == 17 && controlConsidered) {
ctrlPressed();
}
}
document.addEventListener('keydown', keydownhandler, false);
document.addEventListener('keyup', keyuphandler, false);
另一答案
这并不是完全被问到的,但是对于好奇的,下面的代码可以处理单个控制键按下和双控制键按下。它的工作原理如下:
- 完全按照Josiah's answer中的描述检测有效的单一控制键事件。如果检测到,则发射
ctrlPressed
,其中: - 跟踪按下控制键的前两个时间戳,
- 每次触发时,初始化特定
threshold
值(以毫秒为单位)的超时,并且, - 如果存在控件双击(时间戳差异在阈值内),则先前的超时被取消,否则不被取消。
var lastControlTime = 0,
newControlTime, timeout,
threshold = 200;
function ctrlPressed() {
newControlTime = new Date();
var bool = newControlTime - lastControlTime <= threshold;
if (!bool)
timeout = setTimeout(function() {
if (timeout) {
alert("Single control key pressed");
timeout = undefined;
}
}, threshold);
if (bool) {
alert("Double control key pressed");
clearTimeout(timeout);
timeout = undefined;
}
lastControlTime = newControlTime;
}
function keydownhandler(e) {
var key = e.which || e.keyCode;
controlConsidered = (key == 17);
}
function keyuphandler(e) {
var key = e.which || e.keyCode;
if (key == 17 && controlConsidered) {
ctrlPressed();
}
}
document.addEventListener('keydown', keydownhandler, false);
document.addEventListener('keyup', keyuphandler, false);
以上是关于如何检测单个控制键盘事件而不是键组合?的主要内容,如果未能解决你的问题,请参考以下文章