我想检测用户是否Enter使用 jQuery按下了按钮。
这怎么可能?它需要插件吗?
编辑:看起来我需要使用该keypress()
方法。
我想知道是否有人知道该命令是否存在浏览器问题 - 比如我应该了解任何浏览器兼容性问题吗?
我想检测用户是否Enter使用 jQuery按下了按钮。
这怎么可能?它需要插件吗?
编辑:看起来我需要使用该keypress()
方法。
我想知道是否有人知道该命令是否存在浏览器问题 - 比如我应该了解任何浏览器兼容性问题吗?
jQuery 的全部意义在于您不必担心浏览器差异。我很确定你可以安全地enter在所有浏览器中使用13。因此,考虑到这一点,您可以这样做:
$(document).on('keypress',function(e) {
if(e.which == 13) {
alert('You pressed enter!');
}
});
我编写了一个小插件,以便更轻松地绑定“按下回车键”事件:
$.fn.enterKey = function (fnc) {
return this.each(function () {
$(this).keypress(function (ev) {
var keycode = (ev.keyCode ? ev.keyCode : ev.which);
if (keycode == '13') {
fnc.call(this, ev);
}
})
})
}
用法:
$("#input").enterKey(function () {
alert('Enter!');
})
我无法得到通过@Paolo Bergantino发布工作的代码,但是当我把它改成$(document)
和e.which
,而不是e.keyCode
后来我发现它完美地工作。
$(document).keypress(function(e) {
if(e.which == 13) {
alert('You pressed enter!');
}
});
我发现这更跨浏览器兼容:
$(document).keypress(function(event) {
var keycode = event.keyCode || event.which;
if(keycode == '13') {
alert('You pressed a "enter" key in somewhere');
}
});
您可以使用 jquery 'keydown' 事件句柄执行此操作
$( "#start" ).on( "keydown", function(event) {
if(event.which == 13)
alert("Entered!");
});