javascript – 如何获取有关按键的持续时间的信息?

前端之家收集整理的这篇文章主要介绍了javascript – 如何获取有关按键的持续时间的信息?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
所以,想象一下这段代码
  1. if (navigator.appName == "Opera")
  2. document.onkeypress = function (e) { console.log(e.keyCode); };
  3. else
  4. document.onkeydown = function (e) { console.log(e.keyCode); };

我猜,它的作用非常明显.问题是,如果长时间按住键,它会被注册很多次.在我的应用程序中,这是一个问题,因为它使我的应用程序做了很多不必要的计算.有可能以某种方式只获得一次按键,但有关键持有多长时间的信息?

谢谢.

解决方法

干得好:
  1. var pressed = {};
  2.  
  3. window.onkeydown = function(e) {
  4. if ( pressed[e.which] ) return;
  5. pressed[e.which] = e.timeStamp;
  6. };
  7.  
  8. window.onkeyup = function(e) {
  9. if ( !pressed[e.which] ) return;
  10. var duration = ( e.timeStamp - pressed[e.which] ) / 1000;
  11. // Key "e.which" was pressed for "duration" seconds
  12. pressed[e.which] = 0;
  13. };

现场演示:http://jsfiddle.net/EeXVX/1/show/

(删除URL的“show /”部分以查看演示代码)

因此,您可以使用按下的对象来监视当前正在按下哪些键以及按下它们的时间点(及时).

在keyup处理程序中,确定是否按下了键,如果是,则通过减去keyup / keydown事件的时间戳来计算持续时间.

猜你在找的JavaScript相关文章