使用用户脚本将自定义键盘快捷键添加到带有Tampermonkey的Chrome

时间:2012-11-13 13:57:39

标签: javascript google-chrome keyboard-shortcuts userscripts tampermonkey

我想在某个网页上添加一些自定义键盘快捷键。

使用此问题的接受答案作为指南:How can I add a JavaScript keyboard shortcut to an existing JavaScript Function?

我制作了自己的小功能,并添加了一个听众:

// ==UserScript==
// @name       ChartGame
// @namespace  http://www.chartgame.com/
// @version    0.1
// @description  enter something useful
// @match      http://www.chartgame.com/play*
// @copyright  2012+, You
// ==/UserScript==
function doc_keyUp(e) {
  switch(e.keyCode)
  {
  case 49: //1
    mon_clk(3);
    break;
  case 50:
    mon_clk(6);
    break;
  case 83: //s
    BuySell(0);
    break;
  case 68: //d
    BuySell(1);
    break;
  case 70: //f
    TimelapseDwn();
    TimelapseUp();
    break;
   default:
     break;
  }
}
document.addEventListener('keyup', doc_keyUp, false);

如果我在适当的网页上将其输入Chrome javascript控制台,此代码运行完全正常。我可以像我想的那样使用键盘快捷键。唯一的问题是如果我去下一场比赛(即图表......),我必须重新输入包含听众的javascript代码。

我的印象是Tampermonkey允许我在与@match上的表达式匹配的特定页面上自动运行此脚本。代码似乎运行,但没有键盘快捷键功能。

从Chrome控制台和Tampermonkey等扩展程序运行javascript代码缺少什么或有什么不同?

1 个答案:

答案 0 :(得分:5)

该代码在用户脚本中不起作用,因为它调用目标页面定义的javascript函数。用户脚本在各种沙箱中运行,因此无法轻易看到目标页面的JS。

Tampermonkey(和Greasemonkey)通过unsafeWindow提供了解决方法。 (纯Chrome用户脚本不以任何有用的方式支持unsafeWindow。)

因此,要使用这些函数,请将它们作为前缀:

// ==UserScript==
// @name       ChartGame
// @namespace  http://www.chartgame.com/
// @version    0.1
// @description  enter something useful
// @match      http://www.chartgame.com/play*
// @copyright  2012+, You
// ==/UserScript==
function doc_keyUp(e) {
    switch (e.keyCode) {
        case 49:
            //1
            unsafeWindow.mon_clk(3);
            break;
        case 50:
            unsafeWindow.mon_clk(6);
            break;
        case 83:
            //s
            unsafeWindow.BuySell(0);
            break;
        case 68:
            //d
            unsafeWindow.BuySell(1);
            break;
        case 70:
            //f
            unsafeWindow.TimelapseDwn();
            unsafeWindow.TimelapseUp();
            break;
        default:
            break;
    }
}
document.addEventListener('keyup', doc_keyUp, false);


另一种方法是适用于普通Chrome用户脚本的方法,是Inject your code。但由于您使用的是Tampermonkey,因此在这种情况下只需使用unsafeWindow方法。