これは非常に古い質問です。gilly3の答えは、KeyboardEventタイプのイベントオブジェクトが関数の引数として渡されている場合にのみ有効です。この関数のように使用可能なイベントオブジェクトがない場合、現在のコントロールキーの状態を検出するにはどうすればよいですか?
function testModifierKey() {
  // have I some modifier key hold down at this running time?
}
私はspikebrehmのhttps://gist.github.com/spikebrehm/3747378から長い検索の後に解決策を見つけました。彼の解決策は、グローバル変数でjQueryを使用して、いつでも修飾キーの状態をトレースすることです。
グローバル変数window.modifierKeyは、イベントオブジェクトを必要とせずに、どのような状況でも使用できます。
function testModifierKey() {
  // have I have some modifier key hold down at this executing time?
  if(window.modifierKey) {
    console.log("Some modifier key among shift, ctrl, alt key is currently down.");
    // do something at this condition... for example, delete item without confirmation.
  } else {
    console.log("No modifier key is currently down.");
    // do something at other condition... for example, delete this item from shopping cart with confirmation.
  }
}
HTMLドキュメントにロードする彼のスクリプトは次のとおりです。
// source: https://gist.github.com/spikebrehm/3747378
// modifierKey used to check if cmd+click, shift+click, etc. 
!function($, global){
  var $doc = $(document);
  var keys;
  global.modifierKey = false;
   global.keys = keys = {
      'UP': 38,
      'DOWN': 40,
      'LEFT': 37,
      'RIGHT': 39,
      'RETURN': 13,
      'ESCAPE': 27,
      'BACKSPACE': 8,
      'SPACE': 32
  };
  // borrowed from Galleria.js
  var keyboard = {
    map: {},
    bound: false,
    press: function(e) {
      var key = e.keyCode || e.which;
      if ( key in keyboard.map && typeof keyboard.map[key] === 'function' ) {
        keyboard.map[key].call(self, e);
      }
    },
    attach: function(map){
      var key, up;
      for(key in map) {
        if (map.hasOwnProperty(key)) {
          up = key.toUpperCase();
          if (up in keyboard.keys) {
            keyboard.map[keyboard.keys[up]] = map[key];
          } else {
            keyboard.map[up] = map[key];
          }
        }
      }
      if (!keyboard.bound) {
        keyboard.bound = true;
        $doc.bind('keydown', keyboard.press);
      }
    },
    detach: function() {
      keyboard.bound = false;
      keyboard.map = {};
      $doc.unbind('keydown', keyboard.press);
    }
  };
  $doc.keydown(function(e) {
    var key = e.keyCode || e.which;
    if (key === 16 || key === 91 || key === 18 || key === 17) {
      modifierKey = true;
    } else {
      modifierKey = false;
    }
  });
  $doc.keyup(function(e) {
    modifierKey = false;
  });
}(jQuery, window);