• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >心得技巧 > 盲人站长深恶痛绝的onfocus=”this.blur()”

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

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含盲人站长,onfocus等相关知识,佚名 希望在学习及工作中可以帮助到您

在谈到读屏软件操作页面时,他对我们前端的同学特别的强调:他最深恶痛绝的就是页面链接上有 onfocus=”this.blur()” 这句代码,这从何说起呢?

各种浏览器虚线框差异图

(图一)

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


按下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=”this.blur()”

相关文章

  • 2018-08-23优设首发!800M高质量的iPhone X+8展示模板免费打包下载
  • 2017-08-06你需要知道的18个Web可用性原则
  • 2018-08-23有人说腾讯傻,花几百万买了套字体…
  • 2018-08-23AI+AE教程!教你做一个有趣的搜索动画
  • 2018-08-23超全面!如何做好应用程序中的反馈设计?
  • 2017-08-06css元素隐藏原理及display:none和visibility:hidden
  • 2018-08-23高手进阶技巧!全方位深入理解 Sketch 库(上)
  • 2018-08-23视觉实验!一个让设计师大开脑洞的好方法!
  • 2018-08-23豆瓣9.4!Netflix这部汇集顶级设计师的纪录片,简直拍成了美剧的级别
  • 2018-08-23【2018UCAN】“YUAN”——设计的自我蜕变与重塑,等你来!

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • 别让这些过时的设计元素,毁了你的好设计
    • 沪江UED团队出品!用户体验设计师进阶实战指南(上)
    • 从零基础到入门,这份3个月的高强度字体设计自学计划送给你!
    • js、css、html判断浏览器的各种版本
    • 大产品小细节!5分钟了解格式塔原则
    • 眼见不一定为实!设计中常见的 9 种视觉错觉!
    • 帮助新手熟悉产品的向导程序,遵循着怎样的设计模式?
    • 网页文字设计应该像聪明女孩穿衣服
    • 新手建站入门教程④:如何绑定子目录
    • 就算你不是专业文案,用好这些技巧也能写出1000条好文案!

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有