如何检测单个控制键盘事件而不是键组合?

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-ccontrol-v也会触发事件,似乎事件处理程序无法区分单个controlcontrol中的control-c

我想要的是只允许一键按下并释放,而不是按键组合来触发事件。

答案

您实际上可以使用e.ctrlKeye.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);
另一答案

这并不是完全被问到的,但是对于好奇的,下面的代码可以处理单个控制键按下和双控制键按下。它的工作原理如下:

  1. 完全按照Josiah's answer中的描述检测有效的单一控制键事件。如果检测到,则发射ctrlPressed,其中:
  2. 跟踪按下控制键的前两个时间戳
  3. 每次触发时,初始化特定threshold值(以毫秒为单位)的超时,并且,
  4. 如果存在控件双击(时间戳差异在阈值内),则先前的超时被取消,否则不被取消。

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);

以上是关于如何检测单个控制键盘事件而不是键组合?的主要内容,如果未能解决你的问题,请参考以下文章

js组合键和单个键盘事件

iOS:如何检测硬件蓝牙键盘上的转义/控制键?

在jQuery中检测单个按键事件上的多个键

检测javascript中的键盘错误

vb,如何控制键盘上的ctrl+c组合健和ctrl+v组合健,VB代码如何编写

如何检测是不是在 C++ 中按下了除特定键盘键之外的任何键盘键?