焦点元素
到底哪些元素可以获得焦点呢?默认情况下,只有表单元素可以获得焦点。因为只有表单元素可以交互
让非表单元素获得焦点也是有办法的,先将@H_404_9@tabIndex属性设置为-1,再调用@H_404_9@focus()方法
activeElement
@H_404_9@document.activeElement属性用于管理DOM焦点,保存着当前获得焦点的元素
获得焦点
元素获得焦点的方式有4种,包括页面加载、用户输入(按tab键)、@H_404_9@focus()方法和@H_404_9@autofocus属性
【1】页面加载
默认情况下,文档刚刚加载完成时,@H_404_9@document.activeElement中保存的是body元素的引用。文档加载期间,@H_404_9@document.activeElement的值为null
【2】用户输入(按tab键)
用户通常可以使用tab键移动焦点,使用空格键激活焦点。比如,如果焦点在一个链接上,此时按一下空格键,就会跳转到该链接
说到tab键,就不能不提到@H_404_9@tabindex属性。@H_404_9@tabindex属性用来指定当前HTML元素节点是否被tab键遍历,以及遍历的优先级
1、如果@H_404_9@tabindex=-1,tab键跳过当前元素
2、如果@H_404_9@tabindex=0,表示tab键将遍历当前元素。如果一个元素没有设置@H_404_9@tabindex,默认值就是0
3、如果@H_404_9@tabindex大于0,表示tab键优先遍历。值越大,就表示优先级越小
下列代码中,使用tab键时,button获得焦点的顺序是2、5、1、3