可能的重复: 哪个键代码的转义键与jQuery
如何检测IE, Firefox和Chrome中的escape键? 下面的代码在IE中工作,并提醒27,但在Firefox中它提醒0
$('body').keypress(function(e){
alert(e.which);
if(e.which == 27){
// Close my modal window
}
});
可能的重复: 哪个键代码的转义键与jQuery
如何检测IE, Firefox和Chrome中的escape键? 下面的代码在IE中工作,并提醒27,但在Firefox中它提醒0
$('body').keypress(function(e){
alert(e.which);
if(e.which == 27){
// Close my modal window
}
});
当前回答
注意:keyCode已弃用,请使用key代替。
function keyPress (e) {
if(e.key === "Escape") {
// write your logic here.
}
}
代码片段:
var msg = document.getElementById('state-msg'); document.body。addEventListener('keypress',函数(e) { if (e.key == "Escape") { 味精。textContent += 'Escape pressed:' } }); 按ESC键<span id="state-msg"></span> . /span . > . /span . > . /span . > . /span . > . /span
keyCode已弃用
按下键和按上键似乎都有用,尽管按下键可能不行
$(document).keyup(function(e) {
if (e.key === "Escape") { // escape key maps to keycode `27`
// <DO YOUR WORK HERE>
}
});
哪个键代码的转义键与jQuery
其他回答
下面的代码不仅禁用ESC键,而且还检查按下的条件,根据情况,它将执行或不执行该操作。
在这个例子中,
e.preventDefault();
将禁用ESC键按动作。
你可以用这个来隐藏一个div:
document.getElementById('myDivId').style.display = 'none';
同时考虑按下ESC键的情况:
(e.target.nodeName=='BODY')
你可以删除这个if条件部分,如果你想把它应用到所有。或者你可以在这里设置INPUT,只在光标在输入框中时应用此操作。
window.addEventListener('keydown', function(e){
if((e.key=='Escape'||e.key=='Esc'||e.keyCode==27) && (e.target.nodeName=='BODY')){
e.preventDefault();
return false;
}
}, true);
我认为最简单的方法是使用javascript:
document.onkeyup = function(event) {
if (event.keyCode === 27){
//do something here
}
}
更新:更改key => keyCode
最好的方法是为它构造函数
功能:
$.fn.escape = function (callback) {
return this.each(function () {
$(document).on("keydown", this, function (e) {
var keycode = ((typeof e.keyCode !='undefined' && e.keyCode) ? e.keyCode : e.which);
if (keycode === 27) {
callback.call(this, e);
};
});
});
};
例子:
$("#my-div").escape(function () {
alert('Escape!');
})
纯JS(没有JQuery)
document.addEventListener('keydown', function(e) {
if(e.keyCode == 27){
//add your code here
}
});
使用JavaScript你可以检查工作的jsfiddle
document.onkeydown = function(evt) {
evt = evt || window.event;
if (evt.keyCode == 27) {
alert('Esc key pressed.');
}
};
使用jQuery可以检查工作的jsfiddle
jQuery(document).on('keyup',function(evt) {
if (evt.keyCode == 27) {
alert('Esc key pressed.');
}
});