盲人站长深恶痛绝的onfocus=”this.blur()”

作者:妙净 来源:taobaoUED 时间:2011-04-22 12:25:00 

杭州最美的季节里,淘宝无障碍访问改善小组有幸邀请到盲人在线站长——争渡读屏团队成员——杨永全同学和我们一起面对面交流网站无障碍访问方面的问题。杨同学使用电脑必须使用读屏软件,就像他看不到我们的脸必须靠声音识别我们一样。在谈到读屏软件操作页面时,他对我们前端的同学特别的强调:他最深恶痛绝的就是页面链接上有 onfocus=”this.blur()” 这句代码,这从何说起呢?

(图一)

各位同学,看到这句代码有没有觉得眼熟,对的,你懂的,我们常用它来去除链接取得焦点时外围出现的虚线框(如上图一),google一下,前面几十页谈的都是这个去除虚线框的技巧。但我们也许以前从未想过:我们的这行代码给盲人用户们带来了巨大的困扰:这中断了盲人用户的Tab键路径,导致Tab光标无法聚焦页面的下一个控制器(链接、表单域、object、image map等)。测试如下:

<body>
<a href=”#” >第一个链接</a>
<a href=”#” >第二个链接</a>
<a href=”#” onfocus=”this.blur();”>第三个链接</a>
<a href=”#” >第四个链接</a>
<a href=”#” >第五个链接</a>
<a href=”#” >第六个链接</a>
</body>

按下Tab键,第一和第二个链接都可以正常获取焦点,继续Tab到第三个链接时,悲剧出现了:此时焦点会回到第一个链接,而无法Focus到第四个链接,原因是当Focus到第三个链接时,onfocus=”this.blur()” 事件处理强制触发了失焦,焦点重新回到文档的最开始。于是不停按Tab的结果就是焦点在前面三个链接轮流转,后面的内容通过Tab键无法访问[1]。

(图二)

那么,有更好的方式吗?从根源上看,加onfocus=”this.blur()”是为了去除链接获取焦点后外围的虚线框(当然chrome、safari、opera下的focus效果各异,这里姑且就这么叫吧 )。W3C关于Outline的文章里说明这个虚线框用来告诉用户当前页面获取焦点的元素。我觉得,虚线框的存在有它的合理性,但有时你也许无法回避某些”视觉洁癖”需求(如图二:虚线框使“商品”背景和下面的红色色块分隔开了),以下总结了去掉虚线框的几种常用方法:

去除虚线框的方法优劣兼容性是否中断tab
<a href=”#” onfocus=”this.blur()”>this blur</a>链接聚焦触发时失去焦点,js和html耦合在一起没有兼容性问题
a:focus {outline:none}或
a{outline:none}
outline由css2.1引入,去除虚线框视觉上的问题正是css的职责ie6/ie7不支持,ie8+/ff /safari/opera[2]支持
<a href=”#” hidefocus=”true” >hidefocus</a>该属性是ie的私有属性[3]ie5+支持
a { noFocusLine: expression(this.onFocus = this.blur())}可批量处理,但expression的性能问题不能忽视expression ie6/7支持,ie8+、非ie不支持

综合以上,去除链接虚线框的推荐方法是:ie下用hidefocus属性,ff/chorme/opera/safari下用outline:none。即:

<a href=”#” hidefocus=”true” >链接</a>
a:focus {
    outline:none;
}

杨永全同学无奈地说,如果页面因为onfocus=”this.blur()”导致tab无法访问页面全部内容,争渡读屏软件在读取页面之前会强制过滤掉这个属性,但是如果用户是在js里面动态触发this.blur(),读屏软件又要出新招来克制了。这无疑增加了读屏软件的开发工作量,为了让盲人用户们能更顺畅的访问我们的网站,尽量避免使用onfocus=”this.blur()”哦。

注释

[1]Safari默认情况下,按tab键是不会focus链接的,但会focus表单域,在偏好设置-高级勾选“按下tab以高亮显示网页上的每一项”可开启该功能。Opera比较特殊,它通过shift+上下左右方向键可以向上下左右focus页面焦点。

[2]在Opera下点击链接(focus和active状态)时都不会出现所谓的虚线框,所以Opera下链接的虚线框问题可以不计。 Opera 通过shift+上下左右键产生的线框通过outline:none并不能去除,但是Opera支持outline这个属性。

[3]hidefocus属性是ie的私有属性,虽然hidefocus属性有true or false两个值,但测试结果是ie5-ie9不管其值为true or false, 只要添加hidefocus属性,该链接都会失去虚线框。

标签:站长,onfocus,读屏
0
投稿

猜你喜欢

  • python数组排序方法之sort、sorted和argsort详解

    2021-02-01 19:26:12
  • 使用python3 实现插入数据到mysql

    2024-01-15 07:53:22
  • 提升Python运行速度的5个小技巧

    2021-07-28 20:25:24
  • 基于javascript实现表格的简单操作

    2024-04-30 08:55:24
  • Python复制Word内容并使用格式设字体与大小实例代码

    2023-01-10 05:48:20
  • Tensorflow: 从checkpoint文件中读取tensor方式

    2022-07-20 11:39:29
  • Bootstrap图片轮播效果详解

    2023-08-24 20:31:55
  • Keras函数式(functional)API的使用方式

    2023-09-19 05:52:15
  • 使用setup.py安装python包和卸载python包的方法

    2023-01-31 02:20:47
  • SQL Server 2005:数据类型最大值

    2009-06-04 09:55:00
  • 在python中获取div的文本内容并和想定结果进行对比详解

    2021-09-05 07:29:37
  • python配置虚拟环境步骤

    2023-10-22 09:34:51
  • python爬虫模拟登录之图片验证码实现详解

    2022-06-30 00:07:29
  • python win32 简单操作方法

    2022-05-23 01:47:42
  • numpy 数组拷贝地址所引起的同步替换问题

    2023-11-07 18:00:06
  • Python psutil模块简单使用实例

    2023-08-10 21:15:37
  • Flask处理Web表单的实现方法

    2021-10-20 17:13:36
  • 简单瞅瞅Python vars()内置函数的实现

    2021-03-29 20:41:05
  • 详解Python Opencv和PIL读取图像文件的差别

    2023-09-14 07:36:00
  • Python实现手机号自动判断男女性别(实例解析)

    2021-06-24 21:47:28
  • asp之家 网络编程 m.aspxhome.com