我有一个巨大的输入表单和字段供用户输入。
在用户使用tab键移动到下一个feild的表单中,有一些隐藏字段和只读文本框,其中使用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);" >
答案 0 :(得分:12)
使用jQuery,您可以执行此操作:
$('input, select').keydown(function(e) {
if (e.keyCode==40) {
$(this).next('input, select').focus();
}
});
按下向下箭头键(keyCode 40)时,下一个输入将获得焦点。
编辑:
在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'));
请注意,您可能也希望映射向上键,然后转到最后一个输入,等等。我让您根据具体要求处理细节。
答案 1 :(得分:4)
这是我最后的工作代码:
$('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();
}
});
答案 2 :(得分:0)
如果我理解正确,某些字段是只读的,因此tab键仍然激活它们,即使它们是只读的,这很烦人,因为你必须按下标签关键或许几次到达下一个可编辑字段。如果这是正确的,那么另一种解决方案是在输入字段上使用tabindex
属性,为每个属性编制索引,以便不选择只读和其他不可编辑的字段。您可以在tabindex属性here上找到更多信息。