我正在尝试在WebApp中嵌入一些关键,并且在歌剧中遇到了困难。我有此代码:

window.onkeydown = function(e){
  var key = e.keyCode ? e.keyCode : e.charCode ? e.charCode : false;
  if (e.ctrlKey && key === 84) {
    alert("foo");
    e.preventDefault();
    // return false;
  }
}

它像Firefox和Chrome中的魅力一样工作,但Opera仍然打开新标签。同样也发生了 return false;.

我的信息: Opera/9.80 (X11; Linux i686; U; en) Presto/2.7.62 Version/11.00

有帮助吗?

解决方案

歌剧 不支持 preventDefaultkeydown, ,只有 keypress.

如您所见 这个示例, ,您应该绑定一个单独的 keypress 歌剧处理程序(适应您的情况):

var cancelKeypress = false;

document.onkeydown = function(evt) {
    evt = evt || window.event;
    cancelKeypress = (evt.ctrlKey && evt.keyCode == 84);
    if (cancelKeypress) {
        return false;
    }
};

/* For Opera */
document.onkeypress = function(evt) {
    if (cancelKeypress) {
        return false;
    }
};
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top