- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在制作一个可访问的网站菜单,并希望区分鼠标“单击”和 VoiceOver“按下”来打开子菜单。当我 console.log 事件时,鼠标事件会在 VoiceOver“按下”而不是键盘事件上触发。
有办法区分吗?
当前菜单是基于鼠标悬停的,我已阻止 Click 事件切换子菜单。然而,我希望仅使用键盘的用户能够使用屏幕阅读器打开子菜单,该子菜单指示用户使用命令+选项+空格键进行按下,从而触发鼠标事件“单击”...
我现在正在研究的一个解决方案是仅在悬停处于事件状态时禁用点击事件...
更新:
目标:为可以看到的人触发大型菜单弹出窗口,并链接到为看不到的人显示大型菜单链接的页面。根据我的研究,大型菜单即使编码精美,对于视障人士来说也是一种痛苦。即使 aria 可以知道菜单项是可扩展的,但识别菜单具有扩展功能并不直观,但似乎不会在扩展时发出通知。我认为这对于用户导航到新页面并跳到大型菜单链接的内容来说会是更好的体验。
解决方案:通过使用事件监听器集合,我能够成功且独立地定位键盘 ENTER 单击、VoiceOver/屏幕阅读器单击和鼠标单击。
在鼠标移入菜单项时,我设置了一个阻止点击标志,在鼠标移出时,我删除了该标志,以便单击菜单项时不会跟随链接,而只会打开子菜单。
在按键时,我检查是否按下了“enter”键。如果是这样,我会显示子菜单并阻止链接被跟踪,以便用户和选项卡浏览大型菜单项。
这使得屏幕阅读器点击链接进入专门显示大型子菜单的页面。
或者,对于屏幕阅读器,我可以打开子菜单并将键盘焦点发送到子菜单的第一个元素。不确定这对用户来说是否更直观。
评论:如果您认为此解决方案存在问题,请告诉我。到目前为止效果很好。它假设人们的运动控制问题和良好的视力使用 Tab + Enter 进行导航,而视力受损的人则使用屏幕阅读器单击等效项,例如。 VoiceOvers Command+Option+空格。
最佳答案
您将从这篇博文中注意到,不可能天真地区分鼠标用户和屏幕阅读器用户
http://unobfuscated.blogspot.com/2013/05/event-handlers-and-screen-readers.html
即使有可能,尝试这样做也会被视为侵犯隐私,因为这相当于用户将自己标识为残疾人。没有任何理由想要这样做 - 您的用例是什么?
您的解决方案将适用于除触摸设备之外的任何地方,触摸设备不存在悬停,但是话虽这么说,您会遇到太多麻烦。只要您对大型菜单进行语义标记,盲人用户就可以轻松导航。
看看https://www.capitalone.com/一个合理可访问的大型菜单实现。
关于javascript - 区分鼠标 "click"和屏幕阅读器 "Press",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30056369/
我在按下按钮后制作了一个扩展表单,但现在我也想添加 Enter 按键,但我不知道如何操作。也许有人可以帮助我!? 代码 $(document).ready( function() {
基本上我使用的是 z-index,通过单击按钮,它应该拍摄背面照片并将其置于正面,反之亦然。我目前正试图让按钮正常工作。 Lab 5, Part 1
这个问题已经有答案了: AlertDialog OnBackPressed() Not Working Properly (3 个回答) 已关闭 4 年前。 我想实现抽屉导航后按对话框上的对话框后按。
我有一个点击功能,长按同一个按钮。实现了长按事件,但我需要分别找到按钮 UP_EVENT 和 DOWN_EVENTS。如何使用 OnLongClickListener 实现 View.OnLongC
我需要简单地检测每时每刻在我的 Qt5/C++ 应用程序中何时按下或释放右键。 到目前为止,我已经编写了这些函数: void test::mousePressEvent(QMouseEvent *ev
我有一个输入框和它下面的“添加”按钮。添加按钮基本上所做的是,它将一个新的输入字段附加到文档中。我在这里尝试做的是,在输入字段中键入时,如果检测到返回键按下,调用添加新输入字段的函数将被触发,与单击添
我正在使用 Java swing 和 Matlab 开发一个项目。我有一个带有 2 个按钮“运行”和“暂停”的 GUI。我正在使用另外一个 java 程序 (Matlabjavaprog.java),
目前,我有一个带有 9 补丁图像作为边框的自定义 View 。 该自定义 View 在 LinearLayout 中放置了三次,所以它看起来像这样: +------------------------
我正打算用一个 TButtonedEdit 控件替换 TEdit + TButton 组合,但当我尝试测试它时,我发现无法使用键盘“按下”(右)按钮。 我尝试了 Alt+Enter、Alt+Down、
您好,我在模糊()和回车键上执行相同的代码时遇到了一些麻烦。我使用以下代码: $(".formatted-date").bind('blur keyup',function(e) { if
这是一个关于android java编程的一般问题。 有没有办法(当手机锁定时)检测是否按下主页按钮几秒钟? 最佳答案 由于不需要硬件按钮,因此并非所有手机都可以使用主页。 关于java - 手机锁定
我在 Pane 中有一个 ImageView,并且该 Pane 已设置 MouseEventHandler 来执行一些操作。 ImageView 的图像在 CSS 文件中定义如下: .imageVie
我需要以编程方式从交互功能内部按下一个键。以下是我目前所掌握的内容的概要: (defun answer-to-life-the-universe-and-everything () (intera
我正在尝试做一个简单的选择器。 这是我的选择器 xml 代码,名为“butt.xml”: 这就是布局: 这就是代码: ImageButton ib; @Override public vo
基本上我是在调用 API 来检索慈善机构列表。然后我将所有这些放在一个数组中并动态设置 UIButtons。 然后我允许用户选择慈善机构并显示包含该索引数据的 View 。 我的循环在这里; for
让我解释更多细节。 首先;我知道如果用户按回键并返回上一个 Activity ,则上一个 Activity 会正确触发 onResume 方法。这没关系。 我的应用程序中有一个根 Activity ,
我正在使用 BootStrap Group Button 类,发现在我自己的代码中,如果按下一个按钮,该按钮将在几秒钟后弹出.... 如何确保它保持按下状态? Stage
我有一个 ListView,当通过 onItemClick 监听器单击项目行时,它会打开另一个 Activity 。 我希望该行从被点击到屏幕切换到新 Activity 时一直保持按下状态。我认为这对
我正在使用 Hammer.JS 来检查事件。我想长按做一些事情。所以我正在使用像这样的锤子新闻事件 var mc = new Hammer(can); mc.on("press", function
我构建了一个 Swing GUI 应用程序,除了一些细节之外,一切都运行良好:我有两个按钮,每个按钮都附加了一个鼠标单击事件。问题是,当我单击它们时,它们保持“按下”状态:其他一切都正常,但看到这两个
我是一名优秀的程序员,十分优秀!