1. 给你的logo添加替代文本
这样有两个好处:屏幕阅读器能识别logo图片代表的含义,图片未加载到时,也能告诉非视障用户那里是你的logo。
几种方法:
<img src=logo.png alt=网页教学网>
或者,你用背景图来实现logo的话,也可以添加title属性来实现:
<span title=网页教学网></span>
当然,链接+背景图的方式是最好的,但最好也加上title属性:
<a title=网页教学网>网页教学网</a>
2.添加基本的landmarks
aria landmark是w3c定义的一套网站可用性规则,对于网站不同的模块添加描述性的landmark——或者直接叫role,有利于读屏软件更好的理解你的网页,从而让视障用户更好的使用你的网站。
<nav role=navigation>
<form action=search.php role=search>
3.增强focus定义
其实很多网站会用尽一切办法去掉浏览器的:focus样式,特别是对于ie浏览器,其实,浏览器默认带上:focus样式是有道理的,它能指示用户当前的鼠标焦点位置是在哪里。这个对于键盘流特别重要。
所以请不要去掉:focus样式,甚至,你觉得默认的样式不好看或者不统一(ie是虚线框,webkit是高亮的实线框,并且,safari是蓝色,chrome是橙色)也可以自己给定义一个高亮色:
a:focus{
background:yellow;
}
如果你的产品经理或者视觉设计师坚持要去掉focus状态的话,把ta的鼠标拿走一天并告诉ta只能用tab切换链接就好了。。。
4.定义必填表单项
用aria-required属性可以定义表单中的必填项——嗯,主要还是告诉读屏软件:
<input type=text name=username aria-required=true>
5.给你的页面添加一个h1
原因很简单,不只是有利于seo,对网站整体的可用性和可读性都很有帮助。另外,你没有代码洁癖么?
6.定义表格的表头
通常很多人习惯表格全部使用td标签,其实,表格不止有hd标签,还有th、col、scope等。
所以简单来说,表头换成th标签吧:
<th scope=col>date</th>
7.定义表格描述
不要简单的在表格前面/后面加个p了事了,表格有专用的caption标签可用,就像图片一样。
<table>
<caption>class schedule</caption>
<tr>
……
8.避免“点击此处”
虽然这样的链接描述对普通人都无所谓,但是对读屏软件来说,是相当糟糕的,它其实是对视障用户的一种干扰。
所以,直接把链接用到正地方吧。
9.去掉tabindex
曾经,很多人用tabindex来“增强”用户体验,但是这个属性却会打乱页面的正常阅读顺序,对视障用户是灾难性的,对普通用户也未必是友善的。
所以千万不要滥用tabindex属性。
10.在线检测一下
看到这里发现其实是个广告,但是如果能检测出来网站可用性问题,也是件好事情,webaim开发的一个网页工具,输入url就会自动检测。