【问题标题】:Focus the next input with down arrow key (as with the tab key)使用向下箭头键聚焦下一个输入(与 tab 键一样)
【发布时间】:2016-04-04 16:24:59
【问题描述】:

我有一个巨大的输入表单和字段供用户输入。

在用户使用 tab 键移动到下一个字段的表单中,有一些隐藏字段和只读文本框在使用 javascript 禁用 tab 键之间。

现在用户发现很难使用 Tab 键,并希望在键盘的向下箭头键上具有相同的功能。

我正在使用下面的代码来调用 js 上的 tab 键代码但不起作用,请一些人帮助我。

function handleKeyDownEvent(eventRef)
{ 
 var charCode = (window.event) ? eventRef.keyCode : eventRef.which;

 //alert(charCode);

 // Arrow keys (37:left, 38:up, 39:right, 40:down)...
 if (  (charCode == 40) )
 {

  if ( window.event )
   window.event.keyCode = 9;
  else
   event.which = 9;

  return false;
 }

 return true;
}

<input type="text"   onkeydown=" return  handleKeyDownEvent(event);" >

【问题讨论】:

标签: javascript


【解决方案1】:

使用jQuery,您可以这样做:

$('input, select').keydown(function(e) {
    if (e.keyCode==40) {
        $(this).next('input, select').focus();
    }
});

当您按下向下箭头键 (keyCode 40) 时,下一个输入将获得焦点。

DEMO

编辑:

在 Vanilla JS 中,可以这样做:

function doThing(inputs) {    
    for (var i=0; i<inputs.length; i++) {
        inputs[i].onkeydown = function(e) {
            if (e.keyCode==40) {
                var node = this.nextSibling;
                while (node) {
                    console.log(node.tagName);
                    if (node.tagName=='INPUT' || node.tagName=='SELECT') {
                        node.focus();
                        break;
                    }
                    node = node.nextSibling;                
                }
            }
        };
    };
}
doThing(document.getElementsByTagName('input'));
doThing(document.getElementsByTagName('select'));

请注意,您可能还想映射向上键,然后转到最后一个输入的第一个输入,等等。我让您根据您的确切要求处理详细信息。

【讨论】:

  • @Neal +1 和很多人一样,我对 Javascript 和巧克力有点太习惯了。如果需要移植到 vanilla js,nextSibling 是一个不错的选择。
  • @Neal 但你仍然想过滤输入,这不能用 nextSibling 完成,所以你必须循环:(
  • 所以循环@dystroy!这就是.next() 所做的! See the .map function
  • 我将它移植到 vanilla js 中。只是因为我们必须保持我们的头脑能够做到这一点。但这更乏味,即使它可以更短。
  • @dystroy,你会如何处理 js
【解决方案2】:

这是我最后的工作代码:

$('input[type="text"],textarea').keydown( function(e) {
    var key = e.charCode ? e.charCode : e.keyCode ? e.keyCode : 0;

    if(key == 40) {
        e.preventDefault();
        var inputs = $(this).parents('form').find(':input[type="text"]:enabled:visible:not("disabled"),textarea');

        inputs.eq( inputs.index(this)+ 1 ).focus();
        inputs.eq( inputs.index(this)+ 1 ).click();
    }
});

【讨论】:

  • 我只是想念 :not("readonly").但有了它,它就像一种魅力,谢谢你。
【解决方案3】:

如果我理解正确,有些字段是只读的,所以即使它们是只读的,tab 键仍然激活它们,这很烦人,因为你必须按下 tab键可能几次以进入下一个可编辑字段。如果这是正确的,那么另一种解决方案是在您的输入字段上使用tabindex 属性,为每个字段编制索引,以便不选择只读和其他不可编辑的字段。您可以在 tabindex 属性here 上找到更多信息。

【讨论】:

  • @strout,我可以为只读字段禁用 tabindex,我需要在向下箭头键上实现 tab 键功能..谢谢
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-08-18
  • 2013-12-10
  • 1970-01-01
  • 2018-10-23
相关资源
最近更新 更多