在HTML中tabindex属性的用途是什么?


当前回答

Tabindex是一个全局属性,负责两件事:

它设置了“可聚焦”元素和的顺序 它使元素“可聚焦”。

In my mind the second thing is even more important than the first one. There are very few elements that are focusable by default (e.g. <a> and form controls). Developers very often add some JavaScript event handlers (like 'onclick') on not focusable elements (<div>, <span> and so on), and the way to make your interface be responsive not only to mouse events but also to keyboard events (e.g. 'onkeypress') is to make such elements focusable. Lastly, if you don't want to set the order but just make your element focusable use tabindex="0" on all such elements:

<div tabindex="0"></div>

同样,如果你不想通过tab键来聚焦,那么使用tabindex="-1"。例如,当使用tab键遍历时,下面的链接将不会被聚焦。

<a href="#" tabindex="-1">Tab key cannot reach here!</a>

其他回答

HTML tabindex属性负责指示一个元素是否可以通过键盘导航访问。 当用户按Tab键时,焦点从一个元素转移到另一个元素。通过使用tabindex属性,制表符顺序流被移位。

简单来说,tabindex用于关注元素。 语法:tabindex = " numeric_value " 这个numeric_value是element的权重。较低的值将首先访问。

它可用于更改默认的表单元素焦点导航序列。

如果你有:

text input A

text input B

submit button C

通过使用tab键,您可以通过A->B->C进行导航。Tabindex允许你改变这个流程。

通过控件的标签通常在控件出现在HTML代码中时按顺序发生。

使用tabindex,制表符将按照tabindex顺序从最低的控件流向最高的控件

你设置的值决定了你的键盘焦点在网站元素之间移动的顺序。

在下面的例子中,当你第一次按tab键时,你的光标将移动到#foo,然后是#awesome,然后是#bar

<input id="foo" tabindex="1"  />
<input id="bar" tabindex="3"  />
<input id="awesome" tabindex="2"  />

如果您没有在任何地方定义标签索引,键盘焦点将按照HTML文档中定义标签的顺序跟随页面的HTML标记。

如果你标签的次数超过了你指定的标签索引,焦点将会移动,就好像没有标签索引一样,也就是说,按照HTML标签出现的顺序