如何使用tabindex-Javascript而不是jquery来查找元素
How can i find an element using tabindex - Javascript not jquery
在一个元素中输入数据后,我正试图将焦点转移到下一个元素。
如何使用tabindex并移动焦点来获取下一个元素。
我正在用扫描仪输入数据。所以钥匙扣上的一秒钟延迟就会说明问题是否输入数据。由于它是扫描仪,用户没有浏览器选项卡。
<tr>
<td class='form' align='center'> <input type='text' tabindex=1 onkeyup='moveNext(this);' id='from' name='elem1' size='5' value=''> </td>
<td class='form' align='center'><input type='text' tabindex=2 onkeyup='moveNext(this);' id='item' name='elem2' size='5' value=''> </td>
<td class='form' align='center' > <input type='text' tabindex=3 id='calc_price' size='10' name='elem3' value=''> </td>
</tr>
我看到了一些答案。全部在jquery中。如何在javascript 中做到这一点
您必须获得当前元素的tabindex,添加1,然后搜索具有该tabindex的元素以将焦点设置为:
function moveNext(elem) {
var tidx = +(elem.getAttribute('tabindex')) +1,
elems = document.getElementsByTagName('input');
for (var i=elems.length; i--;) {
var tidx2 = elems[i].getAttribute('tabindex');
if (tidx2 == tidx) elems[i].focus();
}
}
FIDDLE
这个怎么样
function moveNext(tabInput) {
var lastTab = 3;
var curIndex = tabInput.tabIndex;
var tabs = document.getElementsByTagName("input");
if(curIndex >= lastTab) { //if we are on the last tab then go back to the beginning
curIndex = 0;
}
for(var i=0; i < tabs.length; i++) { // loop over the tabs.
if(tabs[i].tabIndex == (curIndex+1)) { // is this our tab?
tabbables[i].focus(); // Focus and leave.
break;
}
}
获取下一个ID并聚焦它。如果它存在:
let i = document.activeElement.tabIndex;
if(i >= 0){
let iNext = document.querySelectorAll("[tabindex='"+(i+1)+"']");
if(iNext.length > 0){
elNext = iNext[0].getAttribute('id');
document.getElementById(elNext).focus();
}
}
基本上,上面的代码是基于以下示例:
document.querySelectorAll("[tabindex='2']")[0].getAttribute('id');
这是我刚刚编写的一个实现。它有点复杂,因为它过滤掉隐藏和禁用的输入,并处理具有相同选项卡索引的多个元素。到目前为止,它只在Firefox中进行了测试。
咖啡:
getElementsInTabOrder = (form) ->
# Get all focusable form elements
elements = Array.prototype.filter.call form.elements, (element) ->
return false if element.type is 'hidden'
return false if element.disabled
return true
# Get elements grouped by tab index
elementsByTabIndex = []
for element in elements
tabIndex = element.tabIndex
unless elementsByTabIndex[tabIndex]?
elementsByTabIndex[tabIndex] = []
elementsByTabIndex[tabIndex].push element
# Flatten to output array
return [].concat elementsByTabIndex...
getElementByDelta = (element, delta, wrap = true) ->
elements = getElementsInTabOrder element.form
length = elements.length
index = elements.indexOf element
targetIndex = index + delta
# Deal with edge cases
while targetIndex < 0
return null unless wrap
targetIndex += length
while targetIndex >= length - 1
return null unless wrap
targetIndex -= length
return elements[targetIndex]
getNextElement = (element, wrap = true) ->
return getElementByDelta element, 1, wrap
getPreviousElement = (element, wrap = true) ->
return getElementByDelta element, -1, wrap
module.exports = {
getElementsInTabOrder
getElementByDelta
getNextElement
getPreviousElement
}
Javascript:
// Generated by CoffeeScript 1.10.0
var getElementByDelta, getElementsInTabOrder, getNextElement, getPreviousElement;
getElementsInTabOrder = function(form) {
var element, elements, elementsByTabIndex, i, len, ref, tabIndex;
elements = Array.prototype.filter.call(form.elements, function(element) {
if (element.type === 'hidden') {
return false;
}
if (element.disabled) {
return false;
}
return true;
});
elementsByTabIndex = [];
for (i = 0, len = elements.length; i < len; i++) {
element = elements[i];
tabIndex = element.tabIndex;
if (elementsByTabIndex[tabIndex] == null) {
elementsByTabIndex[tabIndex] = [];
}
elementsByTabIndex[tabIndex].push(element);
}
return (ref = []).concat.apply(ref, elementsByTabIndex);
};
getElementByDelta = function(element, delta, wrap) {
var elements, index, length, targetIndex;
if (wrap == null) {
wrap = true;
}
elements = getElementsInTabOrder(element.form);
length = elements.length;
index = elements.indexOf(element);
targetIndex = index + delta;
while (targetIndex < 0) {
if (!wrap) {
return null;
}
targetIndex += length;
}
while (targetIndex >= length - 1) {
if (!wrap) {
return null;
}
targetIndex -= length;
}
return elements[targetIndex];
};
getNextElement = function(element, wrap) {
if (wrap == null) {
wrap = true;
}
return getElementByDelta(element, 1, wrap);
};
getPreviousElement = function(element, wrap) {
if (wrap == null) {
wrap = true;
}
return getElementByDelta(element, -1, wrap);
};
module.exports = {
getElementsInTabOrder: getElementsInTabOrder,
getElementByDelta: getElementByDelta,
getNextElement: getNextElement,
getPreviousElement: getPreviousElement
};
相关文章:
- Javascript 变量使用 jquery 查找变量
- 使用Jquery查找asp.net GridView中的所有复选框
- iframe中的jQuery查找元素不起作用
- 如何使用jquery查找单词匹配
- Jquery查找并输出字典
- jQuery查找最大元素的高度
- 使用jquery查找regex匹配的元素
- 如何使用 jquery 查找表单
- jQuery 查找与条件匹配的元素
- 如何使用jQuery查找下一个文本区域
- Jquery-查找具有给定样式属性的元素
- 使用Jquery查找下一个特定类,并检查它是否有其他类
- jQuery查找最近的按钮并触发点击
- jQuery查找元素,然后组成逗号分隔的列表
- 无法通过jQuery查找来定位层次结构中的对象
- jQuery查找最大用户滚动值
- jQuery查找列类
- 使用jQuery查找输入字段
- 如何使用jQuery查找一组元素的父元素
- 使用类jquery查找当前值