- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我读了很多文章说 HTML 5 表单验证是可访问的(阻止提交表单的 required
属性是一个字段留空),但是当我在 Chrome 和 BackTalk 上的 NVDA 上测试我的表单时在 Android 上,如果我没有填写输入,它会重新聚焦到输入字段(这很好!)但是两个屏幕阅读器都会宣布“请填写此字段”,这对用户来说是无用的,因为他们没有宣布该领域的标签。
所以单独的 HTML5 验证是不可访问的?另外,你能把 HTML5 验证和自定义 JS 结合起来吗?
您是否必须编写自定义客户端站点验证才能使表单可访问?
最佳答案
简答
是的,标准 HTML5 验证是可访问的,并将通过 WCAG2.1 AA,但你可以做得更好使用一些 JavaScript。
长答案
如果您需要支持 Internet Explorer 9 或更低版本,那么您将需要使用 JavaScript(根据 WebAim survey - “浏览器”部分仍然涵盖大约 3.6% 的屏幕阅读器用户)。
原生 HTML5 验证是一个很好的起点,但有一些限制(您在评论中给出了一个,一些屏幕阅读器 (NVDA) 不会再次宣布标签,这意味着用户必须亲自要求通过控件读取标签)。
另一件事是,一旦你离开一个字段,它通常不会告诉你你犯了一个错误,直到你提交了表单(它的意思是,但情况并非总是如此,这取决于你的宣布速度、设置和浏览器) .
例如更新 aria-invalid
对于即时反馈很有用(并为旧版浏览器提供支持,同时使用“不寻常”的屏幕阅读器更加强大)。
使用 aria-live
地区提供即时反馈onblur
(或节流/去抖动)也很有用,是更好的解决方案。
另一件事是 native 验证实际上并不是很有效。例如,fff@fff 显示为有效的电子邮件,并允许在 type="email"
上提交表单。字段,与 type="url"
相同它将允许 https://fff
提交(至少在 Chrome 中)。
我可以继续做其他事情,例如提供有关如何修复错误的更好说明(尤其是对于电话号码之类的问题),但您明白了。
基本上,尽可能多地使用原生 HTML5 功能 为 JavaScript 错误/不使用 JavaScript 的人提供坚实的基础和良好的后备。然后使用 CSS 和 JS 来改善每个人的体验。
Also, can you combine HTML5 validation and custom JS?
document.querySelectorAll('input[type=email]')
可用于选择任何电子邮件输入进行验证或
document.querySelectorAll('input[required]')
查找所有必填字段。
max="100"
之类的东西。在 slider /数字输入上“即时”设置您的验证范围,并且仍然有一个没有 JavaScript 的后备。
关于html - HTML5 表单验证真的可以访问吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59887615/
我正在尝试在两个表之间进行空间连接: 表 1:397265 个特征(在 geom 字段上有 gist 索引) 表 2:73 个特征(在 geom 字段上有 gist 索引) 表 1 和表 2 具有相同
我正在尝试在两个表之间进行空间连接: 表 1:397265 个特征(在 geom 字段上有 gist 索引) 表 2:73 个特征(在 geom 字段上有 gist 索引) 表 1 和表 2 具有相同
枚举类型的值是该类型的静态变量。 据我所知,变量是由引用变量引用的,但没有新的运算符来实例化枚举对象。但这就像初始化数组一样吗? 这是对还是错? 最佳答案 是的,枚举类型的文字是 public sta
我阅读了有关关闭 zsh 自动更正以完成命令的所有提示。但是,它们并没有完全发挥作用。我试过 DISABLE_CORRECTION="true", unsetopt correct, unsetopt
我知道这个问题是 answered before ,但给出的答案并不是完整的故事: 我进入了 Firefox 的 Options->Content 并删除了除德语/德国之外的所有语言,navigato
我知道用汇编语言编写任何内容或将汇编语言添加到任何程序都会损害其可移植性。但是,有多糟糕呢?我的意思是,现在基本上所有 PC 都是 x86 或 x64,对吧?那么,如果我将汇编嵌入到 C 程序中,为什
我正计划构建一个 Web 服务客户端,它始终检查数据库中的某些记录,并根据数据库内容的结果在每个时刻及时执行某些决策。 所以我在想,我怎样才能让客户端一直运行呢? 我唯一想到的就是无限循环。像这样的东
我无法获取小部件的实际背景颜色。在我的特殊情况下,我在使用 QTabWidget 中的小部件时遇到了问题。 这是在 Windows7 上。所以经典小部件有一些灰色背景,而选项卡中的小部件通常用白色背景
请不要将我指向How to wrap preference title?因为它不适用于(正如我评论的那样)您使用 @strings/ 的情况对 strings.xml 文件的引用。 如果你使用 and
情况如下: 已知hdfs是仅附加的(本身没有更新)。 配置单元将数据写入其位于hdfs中的仓库。 可以在配置单元中执行更新 这意味着写入了新数据,旧数据应该以某种方式标记为已弃用,然后在某个时间将其清
在javascript中删除cookies的方法是将过期日期设置为过去。现在这实际上并没有删除 cookie,至少在 Firefox 中是这样。这只是意味着 cookie 将在浏览器关闭时被删除。 这
我需要终止一个卡住的线程,我将 IsBackground 设置为 true 但它仍然存在。线程的属性: ThreadState = AbortRequested IsBackground = true
在逻辑中,以及在 *ahem* 正确设计的编程语言中,将 boolean 值与 true 进行比较总是多余的,即 a == True 应该简单地替换为 a 。 (类似地, a == False 由 n
我一直在努力寻找一个好的定义,并理解线程到底是什么。 看来我一定错过了一些明显的东西,但是每次我读到什么是线程时,它几乎是一个循环定义,la“线程是一个执行线程”或“一种划分运行任务的方法” ”。呃呃
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
是否可以在 MAC 上以真正的全屏模式运行 IntelliJ Idea? 没有工具栏、侧边栏、按钮,只有代码。 如果可以,请告诉我。 最佳答案 您可以通过禁用以下项目在 View 菜单中执行此操作:
考虑以下代码: case class Vector3(var x: Float, var y: Float, var z: Float) { def add(v: Vector3): Unit =
我试图确认这个说法是否属实: 模型包括: 持久层:本质上是 DAO + 表示表的类 + DTO 服务层:DAOS + 一些逻辑的组合 您能否也引用/支持您的回答?我相信我在Spring Framewo
给定代码: #include struct X {}; struct Y1: virtual X {}; struct Y2: virtual X {}; struct Y3: virtual X
从这个其他QUESTION他们谈论 Bjarne Stroustrup 是如何说的,就像比 int 窄的整数数据类型(例如 short)被提升为 int,float 被提升为 double。但是,与i
我是一名优秀的程序员,十分优秀!