42

我想在将动态注入的 HTML 上检测何时按下回车键。

为了简单地检测何时按下回车键,我可以这样做:

$('#textfield').keydown(function (e){
    if(e.keyCode == 13){
        console.log('Enter was pressed');
    }
})

此代码适用于on(),但我担心它效率低下,因为 jQuery 会在每次按下键时进行检查。这有什么低效的吗?

$('body').on('keydown','#textfield', function(event) {
  if (event.keyCode == 13) {
    console.log('Enter was pressed');
  }
}
4

3 回答 3

61

如果您想在页面上的任何位置捕获按键 -

$(document).keypress(function(e) {
  if(e.which == 13) {
    // enter pressed
  }
});

不用担心这会检查每个按键,它实际上并没有给浏览器带来任何显着的负载。

于 2013-02-17T09:02:49.377 回答
10

你仍然可以使用 .on()

$(document).off('keyup#textfield');

$(document).on('keyup#textfield', function(event) {
    if (event.keyCode == 13) {
         console.log('Enter was pressed');
    }
});
于 2014-12-08T16:03:37.203 回答
1

实际上,您无需担心。浏览器已经开始冒泡该事件,即使它可能被body委托事件捕获并运行选择器,这对于 JQuery 执行来说并不是一个深入或困难的实际检查,尤其是对于仅 ID 的选择器.

于 2013-02-17T08:59:04.077 回答