按两个连续键以在JavaScript中触发事件

时间:2010-12-18 14:23:15

标签: javascript vim key keypress keycode

Vim,您可以按gg转到文档的开头,或按dd删除当前行。如何在网页中实现类似的行为?我的意思是,在网页环境中,如何捕获两个连续按键事件来触发事件?

感谢。

2 个答案:

答案 0 :(得分:5)

您需要监控所有按键事件,当您找到可能是多按组合键中的第一个键时,启动计时器。如果在计时器处于活动状态时按下组合中的第二个键,请执行某些操作。

例如(伪代码)

//for gg
var inCombo = false;
function KeyPress(Key) {
   if(Key=='g') {
      if(!inCombo) {
          inCombo = true;
          setTimeout('inCombo=false;', 100);
      } else {
          //Do the action here
      }
   }
}

//Do the action here仅在{100}内按下g

时触发

答案 1 :(得分:3)

你做不到。只需注册普通键事件并将键推送到阵列即可。

现在你可以调用一个检查命令的函数:

 // More or less pseudo code
 function deleteLine(){};
 function copyLine(){};      

 var commands = {'dd': deleteLine, 'yy': copyLine};    

 function onKeyPress(e) {
     keyList.push(e.key);

     // in this example keyList = ['d', 'y', 'i', 'd', 'd']
     var result = handleEvent();
 }

 function handleEvent(keyList) {
      // more pseudo code follows

      var cmds = commands.keyValue.sortByLengthDescending();
      for(var c in cmds) {

          // match the keys
          var ckey = c.split('');
          for(var i = keyList.length; i >= 0; i--) {
              if (keyList[i] !== ckey.shift()) {
                  break;
              }
              if (ckey.length === 0) {
                  return commands[c]();
              }
          }
      }
 }

这很简单,干净(取决于你如何写它)和可扩展,添加更多命令非常简单,当然你改变它以便你可以将参数传递给命令函数等。