”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 构建可访问的 React 应用程序

构建可访问的 React 应用程序

发布于2024-11-04
浏览:150

Building Accessible React Applications

在当今的数字环境中,可访问性不仅仅是一个流行词,而且是必需品。构建可访问的 Web 应用程序可确保所有用户(包括残障人士)都可以有效地与您的内容进行交互。 React 是用于构建用户界面的最流行的 JavaScript 库之一,它提供了多种工具和最佳实践来帮助开发人员创建可访问的应用程序。本文探讨了构建可访问的 React 应用程序的关键策略和技术。

1. 了解网络可访问性

网络可访问性是指设计和开发可供各种残障人士(包括视觉、听觉、运动和认知障碍)使用的网站和应用程序。 Web 内容可访问性指南 (WCAG) 提供了一组开发人员应遵循的标准,以确保所有用户都可以访问其内容。

2. 使用语义 HTML

任何可访问的 Web 应用程序的基础都是语义 HTML。

在 React 中,您应该始终努力使用语义元素而不是通用的

和标签。例如,用于可点击操作而不是与 onClick 事件一起使用。
return 
    
Click me
{/* More accessible */} >

3.正确管理注意力

正确的焦点管理对于键盘导航和屏幕阅读器用户至关重要。 React 提供了多种管理焦点的方法,例如 autoFocus 属性和用于手动设置焦点的 useRef 钩子。

import { useRef, useEffect } from 'react';

function AccessibleForm() {
  const inputRef = useRef(null);

  useEffect(() => {
    inputRef.current.focus(); // Set focus when component mounts
  }, []);

  return ;
}

确保在导航期间将焦点移动到适当的元素,尤其是在实现模式对话框、动态内容或路线更改时。

4. 使用 ARIA 属性

ARIA(可访问的富互联网应用程序)属性可以增强非语义 HTML 元素的可访问性。 React 支持所有 ARIA 属性,允许您在不改变视觉设计的情况下提高可访问性。

例如,使用 role="alert" 向屏幕阅读器宣布重要消息,或使用 aria-live="polite" 更新实时区域。

function Alert({ message }) {
  return 
{message}
; }

但是,ARIA 不应该用作语义 HTML 的替代品。它最适合填补原生元素无法提供必要的辅助功​​能的空白。

5. 无障碍表格

表单是 Web 应用程序的关键部分,使它们易于访问至关重要。确保每个表单控件都有相应的标签。标签元素应使用 htmlFor 属性与其控件显式关联,或者您可以将控件嵌套在标签内。


使用 aria-scribedby 获取与表单控件相关的附加上下文或说明。

We'll never share your email.

6. 处理动态内容

React 应用程序通常涉及动态内容更新。确保所有用户都可以访问这些更新非常重要。使用 aria-live 区域来宣布不会自动聚焦的更改,例如加载指示器或通知区域的更新。

{isLoading ? 'Loading...' : 'Content loaded'}

对于更复杂的状态管理,请考虑与 Redux 或 Context API 等工具集成,以有效地管理和传达状态更改。

7. 辅助功能测试

测试是确保可访问性的重要组成部分。使用 axe-core、Lighthouse 或 React 测试库等工具来自动进行可访问性检查。这些工具可以识别常见的可访问性问题,例如标签丢失、颜色对比度问题和 ARIA 使用不当。

此外,使用键盘导航和屏幕阅读器(例如 NVDA、JAWS 或 VoiceOver)手动测试您的应用程序。这可以帮助您发现自动化工具可能遗漏的问题。

8.色彩对比与视觉设计

确保您的配色方案符合 WCAG 颜色对比度标准。使用颜色对比度检查器或无障碍颜色等工具来验证您的文本在背景下是否可读。

在React中,您可以通过实现CSS变量或使用像styled-components这样的库来动态调整颜色对比度。

const Button = styled.button`
  background-color: var(--primary-color);
  color: var(--text-color);
  &:hover {
    background-color: var(--primary-hover);
  }
`;

9. 无障碍路由

当使用React Router或其他路由库时,确保当路由改变时焦点得到适当的管理。这可以通过在导航事件后将焦点设置到主要内容区域来实现。

import { useEffect } from 'react';
import { useLocation } from 'react-router-dom';

function useFocusOnRouteChange() {
  const location = useLocation();

  useEffect(() => {
    document.getElementById('main-content').focus();
  }, [location]);
}

这可确保屏幕阅读器用户了解上下文更改,并可以轻松导航新内容。

10. 文档和协作

最后,构建可访问的应用程序需要团队的努力。确保所有团队成员,包括设计师、开发人员和 QA 测试人员,都了解可访问性最佳实践。记录您的可访问性标准并将其包含在代码审查中以确保持续合规性。

如何测试 React 可访问性

在检查和测试 React 应用程序中的可访问性时,可以使用推荐的工具。

  • 在文本编辑器中,您可以安装 eslint-plugin-jsx-a11y 等 linter,以在编写 React 应用程序的 JSX 组件时捕获任何可访问性问题。
  • 在开发后期,浏览器中的开发人员控制台与 WAVE Web 可访问性评估工具或 ax DevTools 项目相结合可以帮助诊断和修复任何问题。
  • 您还可以使用屏幕阅读器(例如 NVDA 和 JAWS 屏幕阅读器)分阶段手动测试您的应用程序。

注意:本质上,通过使用 linter 尽早发现可访问性问题,并使用浏览器中的开发控制台和 ax DevTools 验证已修复的可访问性问题,以实现更快、更高效的调试过程。

结论

构建可访问的 React 应用程序需要仔细考虑代码和设计。通过遵循这些最佳实践(使用语义 HTML、管理焦点、利用 ARIA 属性以及彻底测试),您可以创建可供每个人使用的应用程序。请记住,可访问性不仅仅是一个功能,而且是 Web 开发的一个基本方面,可以使所有用户受益。

将可访问性作为优先事项不仅可以改善用户体验,还可以将应用程序的覆盖范围扩展到更广泛的受众。从小事做起,实施这些策略,并不断完善 React 中的可访问性方法。

参考:

  1. React 的辅助功能
  2. MDN 文档
版本声明 本文转载于:https://dev.to/manjushsh/building-accessible-react-applications-3obm?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 开源软件项目的免费人工智能代码审查
    开源软件项目的免费人工智能代码审查
    如果您参与开源软件,您就会知道代码审查的重要性。它们不仅仅是捕捉错误,还确保代码质量、安全性和可维护性,帮助每个贡献者无缝协作。但让我们面对现实吧,代码审查非常耗时。手动审查每个拉取请求 (PR) 可能会减慢开发速度,尤其是在资源有限的开源项目中。 Bito 的人工智能代码审查代理——一种自动化工具...
    编程 发布于2024-11-17
  • 是否可以在 PHP 重定向中设置自定义标头?
    是否可以在 PHP 重定向中设置自定义标头?
    PHP 重定向中的自定义标头:不可能的请求使用 PHP 重定向到页面时,您可能会在尝试通过时遇到挑战以及带有重定向的自定义 HTTP 标头。重定向的标准方法涉及使用 header("Location: http://...") 语法。然而,这种方法只为触发重定向的响应设置标头,而...
    编程 发布于2024-11-17
  • 如何用CSS消除图像间距?
    如何用CSS消除图像间距?
    通过 CSS 消除图像间距在 HTML 中,当连续放置多个图像时,它们之间会出现一个空格。在某些设计场景中,这可能会造成视觉破坏。虽然存在许多解决方法,例如手动换行或 HTML 注释,但有一个使用 CSS 的优雅解决方案。要有效删除图像之间的空白,请利用以下 CSS 属性:img { displ...
    编程 发布于2024-11-17
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2024-11-17
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-17
  • 如何在 Keras 中实现自己的损失函数?
    如何在 Keras 中实现自己的损失函数?
    Keras 中的自定义损失函数实现在 Keras 中,可以实现自定义损失函数来满足特定的训练要求。其中一个函数是骰子误差系数,它测量真实标签和预测标签之间的重叠。要在 Keras 中创建自定义损失函数,请按照以下步骤操作:1。实现系数函数骰子误差系数可以写为:dice coefficient = (...
    编程 发布于2024-11-17
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-11-17
  • Go如何在没有传统机制的情况下实现多态?
    Go如何在没有传统机制的情况下实现多态?
    探索Go语言中的多态性在面向对象编程中,多态性允许对象根据其类表现出不同的行为。但在Go中,多态性的概念并不是传统意义上的实现。让我们深入探究一下这背后的原因,探讨如何在 Go 中实现类似的功能。为什么 Go 缺乏传统的多态性Go 不是传统的面向对象语言。它采用了不同的方法,使用:组合:由其他对象或...
    编程 发布于2024-11-17
  • 如何在Java中正确通过套接字传输文件?
    如何在Java中正确通过套接字传输文件?
    Java 通过套接字传输文件:发送和接收字节数组在 Java 中,通过套接字传输文件涉及将文件转换为字节数组,通过套接字发送它们,然后在接收端将字节转换回文件。本文解决了 Java 开发人员在实现此文件传输功能时遇到的问题。服务器端问题服务器代码在接收时似乎创建了一个空文件来自客户端的数据。为了解决...
    编程 发布于2024-11-17
  • 如何在 JavaScript 中格式化数字以显示最少的小数位数?
    如何在 JavaScript 中格式化数字以显示最少的小数位数?
    在 JavaScript 中格式化数字关于在 JavaScript 中格式化数字的查询,您可以利用内置函数 toLocaleString() 和minimumFractionDigits 选项。toLocaleString() 方法使您能够根据用户的区域设置或指定的区域设置数字格式语言环境。通过将m...
    编程 发布于2024-11-17
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-17
  • 如何在 Go 中将数字转换为字母?
    如何在 Go 中将数字转换为字母?
    在 Go 中将数字转换为字母了解了将数字转换为字母的需要,让我们探索在 Go 中实现这一目标的各种方法.数字到符文的转换一种简单的方法是将数字添加到常量 'A' - 1,其中每个数字相加代表字母表中的一个字母。例如,加 1 得到“A”,加 2 得到“B”。func toChar(i ...
    编程 发布于2024-11-17
  • 如何在 PHP 中提取不带扩展名的文件名?
    如何在 PHP 中提取不带扩展名的文件名?
    在 PHP 中提取不带扩展名的文件名使用神奇常量 __FILE__ 可以轻松获取 PHP 中当前执行脚本的文件名。但是,如果您需要提取不带扩展名的文件名,例如“.php”后缀,则过程略有不同。basename() 解决方案:要使用basename()函数删除扩展名,您可以:basename(__FI...
    编程 发布于2024-11-17
  • 如何在 PHP 和 MySQL 中同步时区?
    如何在 PHP 和 MySQL 中同步时区?
    在 PHP 和 MySQL 中同步时区您正在开发一个需要使用 PHP date() 函数在 MySQL 中存储日期的应用程序。有必要使用 NOW() 在 MySQL 中比较这些日期来计算时间差异。但是,PHP date() 函数使用 PHP 中定义的时区,而 NOW() 使用 MySQL 服务器中配...
    编程 发布于2024-11-17
  • 如何使用准备好的语句在 PHP MySQLi 中准备安全更新查询?
    如何使用准备好的语句在 PHP MySQLi 中准备安全更新查询?
    如何为更新查询准备语句为了增强使用 PHP MySQLi 查询更新数据库时的数据安全性,建议采用准备好的声明。虽然 PHP 文档提供了有关 bind_param() 的信息,但它缺少特定于更新查询的示例。让我们深入研究如何为更新查询制定准备好的语句:准备查询语句:将更新查询中的所有变量替换为问号:$...
    编程 发布于2024-11-17

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3