Skip to main content

Getting started with NVDA

Posted in Accessibility

In my opinion, everyone who works in digital product development should be at the very least familiar with screen reader software. Some, though, should have a working knowledge of how to use it.

I’ve written about how to get started with VoiceOver on macOS but VoiceOver is an Apple-only screen reader so what if you’re a Windows user?

The good news is you’ve got plenty of options, from the built-in Narrator to the two most widely used screen readers in the world: JAWS and NVDA. Let’s talk about the latter.

Page contents:

Install NVDA

NVDA isn’t built in to Windows, so the first thing you need to do is download the most recent version for free.

When setting up, make sure NVDA doesn’t launch on startup as you’re probably not going to want it running all the time. For when you do want to do some testing with it, it’s a good idea to pin the app to your Taskbar so that it’s easy to fire up whenever needed.

Open your web browser

This bit is much easier than with VoiceOver on Mac since NVDA works with any browser you might have on Windows. GOV.UK recommend testing with Firefox, Chrome, or Edge, but every other browser I can think of is based on the same Chromium engine that Chrome and Edge are built on, so you can test with Opera, Brave, Vivaldi; whatever you like.

Having said that, GOV.UK list only Chrome or Edge as the browsers to test with JAWS, so I like to reserve Chromium browsers for JAWS and use Firefox for my NVDA testing; that way I get as broad a sweep of browsers in my testing as possible.

Configure NVDA

Like with most software you test with, the default settings are pretty much what you want to be testing with since very few users will change them.

But there are a few things I do to make NVDA more useable for me, all of which you’ll find by going to NVDA in the Taskbar’s System Tray.

Prevent automatic reading

First up, take full control. By default, NVDA will read its way through all of the content on the page until you stop it. I turn this off in Preferences → Settings… → Browse Mode → Automatically say all on page load.

Disable mouse tracking

Next, keep things keyboard-only. I don’t like that my focus position is moved to where my mouse cursor is hovering if I accidentally nudge the mouse, so I turn off mouse tracking in Preferences → Settings… → Mouse → Enable mouse tracking.

Enable highlighting

I like to see where my cursor is, so I turn on highlighting, which places a blue rectangle around the element that I’m currently focused on. It can be a wee bit buggy sometimes when the page scrolls but I still prefer it. Activate it in Preferences → Settings… → Vision → Enable Highlighting.

Speech viewer

Finally, I turn Speech viewer on in Tools → Speech viewer, which keeps a text-based log of all of the things NVDA reads out. Great in case I miss something it says, or I want to copy/paste something that it read out.

Screen reader software can be noisy, so the first thing to know is how to pause it. Like VoiceOver, the Ctrl key will shut NVDA up. Aside from that, you only need a handful of commands to get around:

(down arrow key)
Go to next thing (heading, paragraph, list item, etc.)
(up arrow key)
Go to previous thing (heading, paragraph, list item, etc.)
(Enter/Return)
Follow a link, press a button, or interact with a form field
Space
Press a button
k
Go to next link (useful for links that appear inside a sentence since, unlike VoiceOver, NVDA doesn’t stop before and after a link)
(Shift) + k
Go to previous link
h
Go to next heading (most screen reader users use headings to find information on a page)
+ h
Go to previous heading

Something else that will come in useful when navigating the web isn’t an NVDA command, but a keyboard-only shortcut that’s available whether you’re using NVDA or not: go back a page with Alt + (left arrow).

Form filling

When you move your NVDA cursor to a form field, it will be read out but, unlike VoiceOver, simply typing will not do anything. In fact, it’ll probably trigger a bunch of NVDA shortcuts that’ll navigate you all over the page, and you’ll end up disoriented.

As mentioned above, to interact with a form field when it has focus, press and start typing (or, if you’re on something like a <select>, use default keyboard behaviour to choose an option). When finished, press the Esc key to go back to exit the form field and go back into ‘navigation mode’.

Take your time

NVDA is a powerful tool and there’s loads more to learn, but that should get you started. Screen reader usage is a very different way to use the web for many of us, and can be noisy and disorienting when you’re getting to grips with it. Patience and persistence are the key: find yourself a quiet spot where you can spend an uninterrupted hour with the software and you’ll be well on your way.

Not only will it give you an amazing insight into one of the many ways people use the web, but it may even offer a better understanding underlying HTML/ARIA that makes up a web page. Good luck!

Accessibility in your inbox

I send an accessibility-centric newsletter on the last day of every month, containing:

  • A roundup of the articles I’ve posted
  • A hot pick from my archives
  • Some interesting posts from around the web

I don’t collect any data on when, where or if people open the emails I send them. Your email will only be used to send you newsletters and will never be passed on. You can unsubscribe at any time.

More posts

Here are a couple more posts for you to enjoy. If that’s not enough, have a look at the full list.

  1. Getting started with VoiceOver on macOS

    Understanding how screen readers work is important for anyone who works on digital products. Here’s how to get started with VoiceOver on macOS.

  2. Using iframes to embed arbitrary content is probably a bad idea

    The iframe element is a way to embed one website inside of another. Useful for things like maps or videos, but not so much for other content.