使用向下箭头键(与tab键一样)聚焦下一个输入
Focus the next input with down arrow key (as with the tab key)
我有一个巨大的输入表单和字段供用户输入。
在用户使用制表键移动到下一个字段的表单中,有一些隐藏字段和只读文本框,在它们之间使用javascript禁用制表键。
现在,用户发现很难使用制表键,并希望在键盘的下箭头键上使用相同的功能。
我使用下面的代码调用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);" >
使用jQuery,您可以执行以下操作:
$('input, select').keydown(function(e) {
if (e.keyCode==40) {
$(this).next('input, select').focus();
}
});
按下向下箭头键(键Code 40)时,下一个输入将接收焦点。
演示
编辑:
在VanillaJS中,可以这样做:
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'));
请注意,您可能也想映射向上键,并在最后一个键处转到第一个输入,等等。我让您根据您的确切要求处理细节。
这是我的最后一个工作代码:
$('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();
}
});
如果我理解正确,有些字段是只读的,所以tab键仍然激活它们,即使它们是只读的。这很烦人,因为你可能需要按tab键几次才能进入下一个可编辑字段。如果这是正确的,那么另一种解决方案是在输入字段上使用tabindex
属性,对每个字段进行索引,这样就不会选择只读字段和其他不可编辑字段。您可以在此处找到有关tabindex属性的更多信息。
相关文章:
- 为什么不't Javascript对我的输入值进行了一些重新检查
- 可以't让我的if语句处理js中的html表单输入
- 使用向下箭头键(与tab键一样)聚焦下一个输入
- 试图清理一个电话号码,以便如果它像816-345-6757一样被输入,它会像8163456757一样返回它
- 如何将 Base64 字符串转换为 javascript 文件对象,就像从文件输入表单一样
- 是否可以使输入像链接(Chrome)一样运行
- 我想将输入的字符串分隔为印度货币格式,就像我输入123456表示一样,那么我想得到 1,23,456
- 当内联链接“#"被点击或输入到url中,就像链接到reddit评论时一样
- 如何让文本像原始输入一样显示在文本区域
- 如何获取html元素运行时代码以生成通用副本?就像复制文本框中输入文本一样
- 下拉选择'它实际上是一个文本输入框,就像谷歌日历一样
- 当javascript函数更改html输入文本时,我希望输入文本像调用其他JS函数一样触发事件
- 模拟'输入'在网站上像人类点击一样按键
- javascript(jquery)数字输入:keyCode for'3'和'#'都是一样
- 这对输入和jquery(This)是不一样的
- 使ul列表像选择输入一样工作
- 在javascript中像表一样输入数据
- jQuery/输入字段(user,pass)就像twitter一样's登录
- 我想要一个锚点应该像输入类型提交按钮一样
- 传递变量,就像Javascript中的输入ID一样