如何创建tabindex组

How to create tabindex groups?

本文关键字:tabindex 创建 何创建      更新时间:2023-09-26

我正在尝试创建tabindex组,其中在一个组中按tab键时,它一直在该组中旋转,直到通过javascript或手动聚焦另一个组。

问题:在没有JavaScript的情况下可以做到这一点吗?如果不能,我如何实现这一点?

这是jsFiddle

HTML代码:

<fieldset>
    <input tabindex="1"/>
    <input tabindex="2"/>
</fieldset>
<fieldset>
    <input tabindex="1"/>
    <input tabindex="2"/>
</fieldset>

编辑:我更希望iframe是解决这个问题的最后手段,在我的应用程序开发的这个阶段很难实现iframe。


这就是我想到的

这是一个相当混乱的代码,但这就是我想到的。将data-tabgroupdata-tabgroupindex添加到input元素将正确地标记它们,而不会脱离组。

正如steveax在这条评论中指出的那样,这不建议没有键盘的用户或在任何常规HTML形式的情况下使用,因为这不是真正必要的。

jsFiddle
中的示例使用过的库

  • lodash.js
  • jquery 1.8.3

HTML代码:

<div>
    <input data-tabgroup="first" data-tabgroupindex="1" />
    <input data-tabgroup="first" data-tabgroupindex="2" />
    <input data-tabgroup="first" data-tabgroupindex="3" />
    <input data-tabgroup="first" data-tabgroupindex="4" />
</div>
<div>
    <input data-tabgroup="second" data-tabgroupindex="1" />
    <input data-tabgroup="second" data-tabgroupindex="3" />
    <input data-tabgroup="second" data-tabgroupindex="2" />
    <input data-tabgroup="second" data-tabgroupindex="4" />
</div>

JavaScript代码:

function isNumber(n) {
    return !isNaN(parseFloat(n)) && isFinite(n);
}
$(document).on('keydown', '[data-tabgroup]', function (e) {
    // TODO
    // Get elements tabgroup [DONE]
    // Find element position by tabgroupindex
    // Check if pressed shift+tab or tab
    // Check if it's first or the last element
    // Check which is next element to focus
    // Focus appropriate element
    if (e.which === 9) {
        var indexNode = $(e.target);
        var nodeIndex = indexNode.data("tabgroupindex");
        var tabgroup = indexNode.data("tabgroup");
        var tabgroupNodes = $("[data-tabgroup='" + tabgroup + "']");
        var tabgroupIndexes = [];
        _.each(tabgroupNodes, function (item) {
            tabgroupIndexes.push(+$(item).data("tabgroupindex"));
        });
        tabgroupIndexes = _(tabgroupIndexes).compact()
            .sortBy(function (num) {
            return num;
        }).value();
        if (isNumber(nodeIndex)) {
            if (e.which === 9) if (e.shiftKey) {
                var nextElement = tabgroupIndexes[tabgroupIndexes.indexOf(nodeIndex) - 1];
                if (typeof(nextElement) === "undefined") {
                    $("[data-tabgroup='" + tabgroup + "'][data-tabgroupindex='" + tabgroupIndexes[tabgroupIndexes.length - 1] + "']").focus();
                    console.log($("[data-tabgroup='" + tabgroup + "'][data-tabgroupindex='" + tabgroupIndexes[tabgroupIndexes.length - 1] + "']").get(0));
                } else {
                    $("[data-tabgroup='" + tabgroup + "'][data-tabgroupindex='" + nextElement + "']").focus();
                }
            } else {
                var nextElement = tabgroupIndexes[tabgroupIndexes.indexOf(nodeIndex) + 1];
                if (typeof(nextElement) === "undefined") {
                    console.log("Im in ")
                    $("[data-tabgroup='" + tabgroup + "'][data-tabgroupindex='" + tabgroupIndexes[0] + "']").focus();
                    console.log($("[data-tabgroup='" + tabgroup + "'][data-tabgroupindex='" + tabgroupIndexes[0] + "']").get(0))
                } else {
                    $("[data-tabgroup='" + tabgroup + "'][data-tabgroupindex='" + nextElement + "']").focus();
                }
            }
        } else {
                $("[data-tabgroup='" + tabgroup + "'][data-tabgroupindex='" + tabgroupIndexes[0] + "']").focus();
        }
        e.preventDefault();
    }
});
JQuery UI有一个:tababble选择器,可以在这里为您提供帮助。
  1. 选择组的所有最后一个选项卡可选择元素
  2. 捕获选项卡输入
  3. 手动选择第一个选项卡可选同级
  4. (对于第一个选项卡可选元素上的Shift+选项卡也是如此。)

JSFiddle

JavaScript

$(function(){
    // Listen for TAB on last child.
    $('fieldset :tabbable:last-child').on('keydown', function(e) {
        if (e.which == 9) {
            e.preventDefault();
            $(this).siblings(':tabbable').eq(0).focus();
        } 
    });
    // Listen for SHIFT + TAB on first child.
    $('fieldset :tabbable:first-child').on('keydown', function(e) {
        if (e.shiftKey && e.which == 9) {
            e.preventDefault();
            $(this).siblings(':tabbable').eq(-1).focus();
        } 
    });
});