JQuery DataTable Keydown

时间:2013-01-30 19:16:17

标签: jquery datatable keydown

我无法使用JQuery DataTable捕获keydown事件。我的目标是允许用户使用箭头键导航表格的行。因此,当用户按下箭头键时,我想捕获keydown事件并移动表的选定行(这是我使用所选行的类在数据表外部跟踪的内容)。但是,我似乎无法抓住keydown事件。

例如,以下代码不起作用:

$('#myTable tbody').keydown(function (event){...});

我的想法是问题是表没有焦点,但也许这是错误的道路。例如,即使我添加以下内容,我也不会使用上面的代码捕获keydown事件:

 $('#myTable tbody').click(function(e){ $('#myTable tbody').focus();});

我可以使用$(文档)捕获keydown,但这是不可取的。

感谢。

1 个答案:

答案 0 :(得分:6)

这是一个有效的解决方案...代码可以清理一下(并且有错误,例如没有限制检查),但效果是:

http://jsfiddle.net/BLSully/Xdkea/

'key'为表格提供tabindex,使其变得“可聚焦”。它不需要为零,但它必须是“某种东西”,以便按键事件在其上工作

<table id="myTable" tabindex=0>
    <tbody>
        <tr><td>Row 1</td></tr>
        <tr><td>Row 2</td></tr>
        <tr><td>Row 3</td></tr>
        <tr><td>Row 4</td></tr>
        <tr><td>Row 5</td></tr>
    </tbody>
</table>

JavaScript的:

$(function(){
    var focusedRow = null;
    $('#myTable').on('keydown', function(ev){
        console.log(ev.keyCode);
        if(focusedRow == null) {
            focusedRow = $('tr:nth-child(1)', '#myTable');
        } else if(ev.keyCode === 38) {
            focusedRow.toggleClass('focused');
            focusedRow = focusedRow.prev('tr');
        } else if(ev.keyCode === 40) {
            focusedRow.toggleClass('focused');
            focusedRow = focusedRow.next('tr');
        }
        focusedRow.toggleClass('focused');
    });
    $('#myTable').focus();
});