当使用 HTML5 属性来标记带有必填字段的表单时,Firefox(以及可能的其他人)中的 JAWS 14 会在用户第一次关注空字段时(即用户第一次遇到该字段)宣布空字段为“无效条目”。
<input type="text" required value="">
使用aria-required="true"
避免了讨厌的消息(并且 JAWS 仍然通知用户该字段是必需的),但是您失去了 HTML5 表单验证功能(阻止表单提交、浏览器生成的工具提示来指导用户等)。
- 如何绕过“无效进入”公告?
- 为什么 JAWS 会这样做?
如果用户跳过它(将其留空,因此无效)然后再次关注它,我会理解将字段描述为“无效”。当前的实现令人困惑,因为用户被告知他们在一个他们甚至不知道存在的字段中输入了错误。
我读过关于aria-invalid
用 JavaScript 设置来愚弄 JAWS 的黑客,但我真的很想避免focus
在具有许多输入的页面上的每个字段上观察用户交互(事件等)。目前我使用<label>Label text <span style="display:none;">required field</span></label>
但这是一个非常hacky、非语义的解决方案(更不用说我失去了 HTML5 的好处required
)。