0

我有这个代码用于在按下一个键时重定向:

$('body').bind('keyup', function(event) {
    if (event.keyCode == 66) { 
        window.location = "page.php"; 
    }
});

我有这个,但重复了大约 10 个不同的键。

CTRL我的问题是,如果用户使用鼠标示例突出显示文本,如果他使用+CCTRL+进行复制或粘贴,我如何使其不适用P

4

2 回答 2

0

显然,JS中没有isKeyDown()函数。也就是说,这应该适合您的需求:

function noMetakeyPressed(metakeysPressed) {
    for (var k in metakeysPressed) {
        if (metakeysPressed[k]) {
            return false;
        }
    }
    return true;
}

var metakeysPressed = {17: false, 18: false};

$('body')
.bind('keydown', function(event) {
    switch(event.keyCode) {
    case 17: // Ctrl
    case 18: // Alt
        metakeysPressed[event.keyCode] = true;
        break;
    case 66: // B
        if (noMetakeyPressed(metakeysPressed)) {
            alert("B pressed");
        }
        break;
    }
})
.bind('keyup', function(event) {
    if(event.keyCode === 17 || event.keyCode == 18) {
        metakeysPressed[event.keyCode] = false;
    }
});

演示

您也可以使用单个isMetakeyPressed布尔变量,但也许您需要知道当前按下的元键。

于 2013-01-30T16:35:17.433 回答
0

检查选定的文本和键:

$('body').on('keyup', function(event) {
   var t = '';
   if(window.getSelection){
       t = window.getSelection();
   }else if(document.getSelection){
       t = document.getSelection();
   }else if(document.selection){
       t = document.selection.createRange().text;
   }
   if ((!t.length) && event.which==66) window.location = 'page.php';
});
于 2013-01-30T16:15:08.010 回答