4

为什么keypress下面的事件在 Chrome 和 Safari 上不起作用?它在 Firefox 中运行良好!

Chrome 和 Safari 我错过了什么?

$(window).keypress(function(event) {                                       

    if ((event.which == 115 && event.ctrlKey) || (event.which == 19)) {

        // Trigger click.
        $("form input[type=submit][name=update]",object_popup).click();
            alert("Keys down are Ctrl + s + Return");

    } else if ((event.which == 120 && event.ctrlKey) || (event.which == 19)){

        // Trigger click.
        $(".ps-button-close",object_popup).click();
        alert("Keys down are Ctrl + x + Return");

    } else {
        return true;
    }

    event.preventDefault();
    return false;
});

当我使用 ctl+s 时 Chrome/Safari 将回退到默认值并保存网页,而当我使用 ctl+x 时会发出警报声。

jsFiddle 演示

4

1 回答 1

5

您必须将代码稍微更改为:

$(document).keydown(function(event) {

  var currKey=0,e=e||event; 
  currKey=e.keyCode||e.which||e.charCode;

    if (!( String.fromCharCode(event.which).toLowerCase() == 's' && event.ctrlKey) && !(event.which == 19))  {
       return true; 
    }    

    event.preventDefault();       
    alert("Keys down are Ctrl + s + Return");     
    return false;

}); 

在线示例

于 2013-10-13T15:58:17.593 回答