找回密码
 注册
搜索
热搜: 回贴
  • 前程无忧官网首页 有什么好的平台可以
  • 最新的销售平台 互联网营销的平台有哪
  • 制作网页的基本流程 网页制作和网页设
  • 【帝国CMS】输出带序号的列表(数字排
  • 网站建设公司 三一,中联,极东泵车的
  • 织梦 建站 织梦网站模版后台怎么更改
  • 云服务官网 哪些网站有免费的简历模板
  • 如何建网站要什么条件 建网站要用什么
  • 吉林市移动公司电话 吉林省退休人员网
  • 设计类毕业论文 网站设计与实现毕业论
查看: 452|回复: 5

用tabIndex轻松实现网页导航

[复制链接]
发表于 2009-3-17 20:04:39 | 显示全部楼层 |阅读模式 IP:江苏扬州
最近,当我在一个网站上输入表格数据时,我填写了一栏,并点击[Tab]键移到下一栏;当我抬头时,我惊奇的发现光标跳到页面下方的另一栏中。我用鼠标将光标移到正确的文本栏中,但不久[Tab]键又再次出现问题。这一情形使我想了解一下页面设计,以及tabIndex属性如何通过键盘帮助导航。
通过[Tab]键访问元素
HTML DOM tabIndex特性允许你设置或返回一个HTML元素的tab键顺序。IE 4.0最先支持此特性。起初,只有真正可通过[Tab]键访问的元素受到支持,如输入栏、链接等。如今,所有的网络浏览器,以及页面上显示的所有元素都支持此特性。在应用它之前,你可以双击HTML规范保证某个元素支持此特性。
tabIndex特性
应用tabIndex特性是一个简单而又直接的过程。例如,下面的HTML源代码将tabIndex值1赋值给输入栏,它是tab顺序的第一栏:
<input id="idfname" name="firstName" tabindex="1" />
如果最初选择了[Tab]键,带这个输入栏的网页会将光标移动到 firstName栏。
在给tabIndex特性赋值时,要留意几个问题。下面是几个赋值规则:
带0值tabIndex的元素根据源代码(或默认页面行为)进行排序。
大于0的tabIndex值设定其tab顺序。所有带正tabIndex值的元素出现在所有带0 tabIndex值的元素之前。
如果你犯了一个错误,把同一个tabIndex赋予给多个元素,像其它元素一样,它们会以一个0值tabIndex进行处理。
将tabIndex赋值为-1,则在使用[Tab]键时,此元素被忽略。注意:如果使用-1值时,onfocus与onblur事件仍被启动。
tabIndex的值可为0至32767之间的任意数字。
列表A中的样本HTML代码将一个tabIndex值赋予给页面中的每一个项目。输入栏与DIV标签包含tabIndex特性,允许用户用键盘仔细阅读页面元素。(DIV标签并不提供与获得焦点有关的太多信息,但我想用非输入元素说明tabIndex的应用情况。)值为-1的按钮被赋值,在应用[Tab]键时,它们即被忽略。
列表A

<html><head>
<title>tabIndex Example</title>
</head>
<body>
<form name="frmTest">
<hr size="3" />
<div id="nameSection" tabindex="1" style="background:silver; padding: 15px;">
First: <input id="idfname" name="firstName" tabindex="2" /><br />
Middle: <input id="idmname" name="middleName" tabindex="3" /><br />
Last: <input id="idlname" name="lastName" tabindex="4" /><br />
</div>
<hr size="3" />
<div id="addressSection" tabindex="5" style="background:gold; padding: 15px;">
Address: <input id="idaddress" name="address" tabindex="6" /><br />
City: <input id="idcity" name="city" tabindex="7" /><br />
State: <input id="idlstate" name="state" tabindex="8" /><br />
Country: <input id="idcountry" name="country" tabindex="9" /><br />
</div>
<hr size="3" />
<div id="addressSection" tabindex=10 style="background:lightblue; padding: 15px;">

Home: <input id="idhome" name="homenumber" tabindex="11" /><br />
Work: <input id="idwork" name="worknumber" tabindex="12" /><br />
Mobile: <input id="idlcell" name="cellnumber" tabindex="13" /><br />
</div>
<hr size="3" />
<div id="buttonsSection" tabindex=14 style="background:green; padding: 15px;">
<input type="button" name="sButton" tabindex="-1" id="idSButton" value="Submit" />
<input type="button" name="cButton" tabindex="-1" id="idCButton" value="Cancel" />
</div></form></body></html>当输入元素充满(达到最大长度)时,你可以增加一小段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的值;如果该值小于最大长度,则焦点被移动下一栏中。
发表于 2010-2-26 21:05:08 | 显示全部楼层 IP:亚太地区
强烈支持。楼主万岁
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-9-29 17:37 , Processed in 0.119561 second(s), 14 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表