日期:2013-07-28 浏览次数:21083 次
最近,当我在一个网站上输入表格数据时,我填写了一栏,并点击[Tab]键移到下一栏;当我抬头时,我惊奇的发现光标跳到页面下方的另一栏中。我用鼠标将光标移到正确的文本栏中,但不久[Tab]键又再次出现问题。这一情形使我想了解一下页面设计,以及tabIndex属性如何通过键盘协助导航。
通过[Tab]键访问元素
HTML DOM tabIndex特性允许你设置或前往一个HTML元素的tab键顺序。IE 4.0最先支持此特性。起初,只要真正可通过[Tab]键访问的元素遭到支持,如输入栏、链接等。如今,所有的网络浏览器,以及页面上显示的所有元素都支持此特性。在使用它之前,你可以双击HTML规范保证某个元素支持此特性。
tabIndex特性
使用tabIndex特性是一个简单而又直接的过程。例如,下面的HTML源代码将tabIndex值1赋值给输入栏,它是tab顺序的第一栏:
如果最后选择了[Tab]键,带这个输入栏的网页会将光标挪动到firstName栏。
在给tabIndex特性赋值时,要留意几个问题。下面是几个赋值规则:
列表A中的样本HTML代码将一个tabIndex值赋予给页面中的每一个项目。输入栏与DIV标签包含tabIndex特性,允许用户用键盘细心阅读页面元素。(DIV标签并不提供与获得焦点有关的太多信息,但我想用非输入元素说明tabIndex的使用情况。)值为-1的按钮被赋值,在使用[Tab]键时,它们即被忽略。
当输入元素充满(达到最大长度)时,你可以添加一小段JavaScript脚本来实现自动定位功用。这是一个基本的函数,我们来看看脚本如何实现其功用:
function checkLen(x,y) {
if (y.length==x.maxLength) {
var next=x.tabIndex
if (next < document.getElementById("frmTest").length) {
document.getElementById("frmTest").elements[next-1].focus()
} } }
该函数接受两个变量。第一个变量为输入栏,第二个变量包含该栏的值。并将栏的长度与栏的可接受最大长度相比较。如果它们相等(即该栏是充满的),则从栏中读取tabIndex的值;如果该值小于最大长度,则焦点被挪动下一栏中。
此函数为每一栏的onkeyup事件赋值,因此每次在栏中输入一个值,以检验其能否达到最大长度时,都要调用该函数。如果达到最大值,则光标按tab顺序挪动到下一栏中。列表B中的源代码将此函数添加到上面的例子中。
提高访问能力
为元素指定tabIndex可协助经常使用键盘的用户更为方便地接触网络界面;非标准用户,如PDA、挪动电话以及残疾人使用的屏幕阅读器也从中受益。任何扩充使用软件功用的事件都是无益的。
大事一桩
你可能要花许多时间来设计网络窗体,使其具有视觉吸引力,并能被后端服务器组件正确处理。但是,你可能忽略了要用非标准技术或浏览器对其进行测试。典型的例子就是放弃鼠标,而依托键盘来导航窗体。HTML标准包含tabIndex特性,它允许你控制通过[Tab]键访问的项目。