首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >区分按键和按键

区分按键和按键
EN

Stack Overflow用户
提问于 2011-08-24 01:01:19
回答 7查看 8K关注 0票数 7

我有一个javascript函数,当‘向下’键被按下时运行。我想,如果“向下”键被按住,函数将根本不会运行。

我考虑了keydown和keyup之间的时间,如果时间小于1秒,那么函数将在keyup上运行。问题是,如果我按住这个键,浏览器会将其视为连续多次按下的键。

有没有更好的方法来做这件事?

谢谢

EN

回答 7

Stack Overflow用户

回答已采纳

发布于 2011-08-24 01:09:56

如果我理解你的问题是你的浏览器将一个按键解释为多个按键事件。您希望在按住某个键的情况下与简单地按下该键时发生一些不同的事情;并且您希望这种差异基于您认为应该构成“持有”键的某个时间。因此,您需要通过跟踪keyup事件来区分按住和按下。下面的伪代码可以解决这个问题:

打开快捷键:

代码语言:javascript
复制
if !yourBool 
    start timer

yourBool = true 

在Keyup上:

代码语言:javascript
复制
if timer < yourTime
    do something

yourBool = false

这将起作用,因为计时器不会重新启动,除非发生keyup事件。

现在..。如果您的浏览器将按键解释为:

快捷键,快捷键......

那么这种方法就有问题了。

票数 1
EN

Stack Overflow用户

发布于 2018-07-20 04:24:50

有一个名为repeat的键盘事件属性,如果按住该键,该属性将返回true。

代码语言:javascript
复制
document.addEventListener('keydown', (event) => {
  if(event.repeat) {
    // key is being held down
  } else {
    // key is being pressed
  }
});
票数 10
EN

Stack Overflow用户

发布于 2011-08-24 01:11:37

我刚写了这个小脚本,用来区分按键和按下200毫秒的按键。也许你可以利用它:

代码语言:javascript
复制
document.onkeydown = function(e){
    var keycode = window.event ? window.event.keyCode : e.which;
    if(keycode == 40){
        var timer = setTimeout(function(){
            alert('Down key held');
            document.onkeyup = function(){};
        }, 200); 
        document.onkeyup = function(){
            clearTimeout(timer);
            alert('Down key pressed');   
        }
    }
};

JSFiddle

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7164735

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档