35

我想添加tabindex到所有表单元素。该表单是动态的,我无法将其添加到 HTML。我想将它作为一个函数运行。

如果有多个同名单选按钮,则每个单选按钮都必须有自己的tabindex值。页面上的大多数表单元素都以 开头<input>,除了<select>. 我该如何解释呢?

我想我需要运行一个循环并添加属性,对吧?

var n = 1; 

$('input, select').each(function() {               
    $(this).attr('tabindex', n++);
});
4

4 回答 4

54

奇怪的问题,但这是基本的想法:

$(":input:not(:hidden)").each(function (i) { $(this).attr('tabindex', i + 1); });

这使用:input来获取包括按钮和文本区域在内的所有内容。:not(:hidden)只会排除隐藏的输入以避免不必要的选项卡。

于 2013-02-27T22:05:30.417 回答
16

最好避免n++设置不同的tabindex数字。

相反,尝试设置tabindex0

$(':input:visible').each(function() {               
    $(this).attr('tabindex', '0');
});

tabindex="0"意味着元素在顺序键盘导航中应该是可聚焦的,但它的顺序由文档的源顺序定义。 ~ developer.mozilla.org

选择:input器基本上选择所有表单控件。

:visible选择器基本上选择所有可见的元素。


或如评论中所建议的那样,如果您没有其他更改可应用于每个可见输入,那么这应该足够了:

$(':input:visible').attr('tabindex', '0');
于 2018-07-26T21:54:45.357 回答
-1

在这里,我描述了如何通过 jquery 动态添加 aria-selected 和 tabindex 值。我还想看看可访问性如何与 tablist、tab 和 tabpanel 角色一起工作,以及 aria 属性如何工作。希望对这段代码有帮助:

 var $tabs = $('.tabs');
 var $panels = $('.panel');

 $tabs.on('click', 'a', function (e) {
 e.preventDefault();
  var id = $(this).attr('href');

  // Find the currently visible tab and panel and hide them
$tabs.find('[aria-selected="true"]').attr({
            'aria-selected': false,
            'tabindex': -1
        });
   $(this).attr({
            'aria-selected': true,
            'tabindex': 0
        });
});

标签包装器:-

<ul class="tabs" role="tablist">
  <li role="presentation"><a href="#tab-1" role="tab" aria-controls="tab-1" aria-selected="true">Tab 1</a></li>
  <li role="presentation"><a href="#tab-2" role="tab" aria-controls="tab-2">Tab 2</a></li>
  <li role="presentation"><a href="#tab-3" role="tab" aria-controls="tab-3">Tab 3</a></li>
</ul>

<div class="tab-panels">
  <div class="panel" id="tab-1" role="tabpanel" aria-hidden="false">…&lt;/div>
  <div class="panel" id="tab-2" role="tabpanel" aria-hidden="true">…&lt;/div>
  <div class="panel" id="tab-3" role="tabpanel" aria-hidden="true">…&lt;/div>
</div>
于 2021-02-19T11:38:55.163 回答
-1

一种方法是将元素在 DOM 中移到更高的位置。与较低的元素相比,DOM 树顶部的元素将首先使用 Tab 聚焦。

于 2021-06-09T16:36:09.510 回答