In the context of software development accessibility refers to the use of assistive technologies to aid users in effectively using the software being developed. When designing interactions through the screen, keyboard, mouse, and speakers it is important to ensure that the widest possible group of users will be able to effectively participate in those interactions.
For software developed with JavaScript the user interface (UI) typically falls into one of the following:
- Browser based UI delivered though JavaScript, HTML and CSS.
- Desktop type application built on something like electron.
- Command line scripts/applications.
Both 1) and 2) above leverage JavaScript, HTML and CSS in a similar manner and we'll use web based applications to describe both of these.
In web based applications, the HTML, JavaScript and CSS run in the browser (or equivalent in frameworks like electron) and is referred to as the front-end. The back-end running on Node.js provides the business logic to the front end through REST APIs, websockets or some other set of APIs.
In this context, the focus on accessibility is in the development of the front-end as opposed to JavaScript running under Node.js in the back-end.
We have outlined above the moral obligation to ensure that our software is accessible. Many jurisdictions also mandate software accessibility by law. For example, in Israel, websites that offer a public service (to exclude, e.g. a private blog) must conform to WCAG 2.0 at the AA level, and businesses that do not comply may be liable for statutory damages. Another good example for requirements in the US public sector is the requirements related to Section 508.
In order to find out about policies that may apply to your jurisdiction, this page from the W3C provides a good starting point.
N/A
The teams experience is that it is useful for organizations and teams building products or components with significant user interfaces to define guidelines and or design systems that apply to their product or organization and help ensure accessibility is planned in from the start. Examples of such guidelines which apply to the work of the team members include:
Developers may also use pre-made components with accessibility features built in:
Users should make sure to read and understand the accessibility documentation for pre-made components. It is also best practice to incorporate testing of your application with common assistive technologies like screen readers and limiting input to keyboard interaction. See tooling below.
For those working on Linux List Of Accessibility Documentation Sources And Tools (For GNU/Linux Development And Testing) provides information on good starting points.
In web based applications most of the accessibility work is done in the front-end. The Web Content Accessibility Guidelines (WCAG) is the recognized standard for making a web application accessible. The teams members have found the WCAG quick reference a useful reference for working with the guidelines. The WAI-ARIA Authoring Practices Examples provide a comprehensive list of exemplary widgets complete with code snippets and live demos.
In the teams experience testing/validation of accessibility requirements will be against the front-end and not the APIs provided by the Node.js back-end. The result being that team members building the front-end must be knowledgeable on accessibility requirements. Back-end Node.js developers, on the other hand, will support requirements that come from the front-end versus driving the accessibility effort.
Server side rendering may blur the line a bit, but most often front-end developers or those with front-end skills should be involved in the development of the HTML that will be rendered on the server and the same guidelines apply as when rendered in the browser.
In addition to supporting requirements driven by the front end, we recommend that Node.js developers:
- build APIs in a way that avoids hard coding resources returned to the front end and ensuring they can provide all required forms of a resource. Resources required by the front-end may need an alternative form in order to support accessibility (For example alternative text for audio, etc.).
- Ensure that error messages are understandable when read aloud. Error messages returned to users may be read by screen readers.
As mentioned in later sections, some tools for accessibility testing are written in Node.js. As a result, Node.js developers may also be involved in helping to automate accessibility testing.
Command line tools have been historically considered more accessible (see Accessibility of Command Line Interfaces for discussion on this topic). For this reason, most if not all of accessibility standards and guidelines are for graphical user interfaces. The team is not aware of standards or guidelines that provide guidance specifically for command line applications.
If you integrate enhanced visual elements (for example color) into your command line interfaces, the team recommends that you review the corresponding sections of the web accessibility guidelines.
Accessibility of Command Line Interfaces provides a number of good recommendations which are not specific to Node.js. These include:
- Ensure that an HTML version of all documentation is available.
- Provide a way to translate long outputs into another accessible format.
- Document the output structure for each command.
- Provide a way to translate tables in CLI output into another accessible format.
- Ensure that all commands provide status and progress indication.
- Ensure that all status and progress indicators used are screen reader friendly.
- Ensure that error messages are understandable when read aloud.
Accessibility tooling is generally not Node.js specific. However some tools are built in Node.js and are delivered through npm. They will, therefore, fit easily in a JavaScript or Node.js workflow when necessary. For example:
- eslint-plugin-jsx-a11y
- axe-core
- pa11y
- web test runner and open-wc testing helpers provide framework-agnostic a11y unit testing tools. See PatternFly Elements'
<pfe-accordion>
for an example of how to write keyboard accessibility tests for interactive widgets
Introduction to the Node.js reference architecture: Accessibility