listen to 'CTRL+N' with javascript

listen to 'CTRL+N' with javascript

本文关键字:javascript with CTRL+N to listen      更新时间:2024-05-01

我正在尝试绑定'CTRL+N'组合键,如下所示:

var ctrlPressed = false;
    var nCode = 78;
    var ctrlCode = 224;
    var cmdCode = 17;
    document.addEventListener ("keydown", function(e){
        if( e.keyCode == ctrlCode || e.keyCode == cmdCode){
            ctrlPressed = true;
        }else{
            ctrlPressed = false;
        }
        console.log(e.keyCode);
    });
    document.addEventListener ("keyup", function(e){
        if(ctrlPressed && e.keyCode == nCode){
             e.preventDefault();
            nou_element(parent);
            return;
        }
    });

请注意:jQuery不可用

问题是e.preventDefault()似乎并没有覆盖bowser 中内置的创建窗口功能

我如何绕过?

您的代码有一些问题:

  • 并非所有浏览器都允许您阻止默认的键盘操作(如Chromium 30)

  • 为了防止它们出现在其他事件(如Firefox或IE8)上,您必须阻止keydown事件而不是keyup事件,因为那样就太晚了。

  • 要检查是否按下Ctrl键,请使用e.ctrlKey

演示(适用于Firefox)

document.addEventListener("keydown", function(e){
    if(e.ctrlKey && e.keyCode == /*key code*/) {
        e.preventDefault();
        /* Do whatever */
    }
});

演示(适用于Firefox和IE8)

document.onkeydown =  function(e){
    e = e || window.event;
    if(e.ctrlKey && e.keyCode == nCode) {
        e.preventDefault ? e.preventDefault() : e.returnValue = false;
        /* Do whatever */
        return false;
    }
};