Styling forms
accessibly

Hi, I’m Amanda

Lead UX Developer at DockYard

@acacheung

Styling forms
accessibly

Web accessibility

The inclusive practice
of removing barriers
that prevent interaction with, or access to websites,
by people with disabilities.

Wikipedia says:

Most studies find that
about one fifth (20%) of the population has some
kind of disability.

WebAIM says:

Visual

Motor

Auditory

Cognitive

Visual

​blindness, low vision,
color-blindness

Motor

inability to use a mouse, slow response time,
limited fine motor control

Auditory

deafness,
hard-of-hearing

Cognitive

learning disabilities,
inability to remember or focus on large amounts
of information

How does this apply
to user experience?

Building for accessibility creates better ​
user experiences.

 

How it feels

Implementation

Beyond the basics

Who it benefits

Small percentage
of users?

Small percentage
of users?

Non-retina display

Projection

Sun glare

Closed captioning

External decoders

 Over half of the TeleCaption decoders are actually sold to the hearing population

Closed captioning

Makes it accessible to the hearing impaired 

  • SEO benefits
  • Search and find
  • Don’t need to listen
    to the audio

Accessibility
benefits everyone!

Who it benefits

 

 

Implementation

Beyond the basics

How it feels

What are accessibility features that we should
be aware of?

Definitions

Associate labels
and inputs

Focus cursor

Larger target areas

Makes it easier for
people with motor disabilities.

As well as people who don't.

Keyboard shortcuts

 through inputs

tab

On mobile, can use < >.

  • ↑↓←→ to choose option for radio button

space
enter
  •              to select checkbox
  • ↑↓←→ and type to choose in a dropdown popup, and select with 

Makes it usable for
blind users and users with low-mobility.

Makes it more efficient
for those who aren’t.

Assistive technology

Who it benefits

How it feels

 

 

Beyond the basics

Implementation

Design + development

Stick to semantic HTML

Semantic HTML is a way
of writing HTML that emphasizes the meaning
of the encoded information

Wikipedia says:

<h1>
<p>
<label>
<input>
<select>

Accessibility is baked in when we begin with semantic HTML.

Semantic HTML

<form>
  <label for="name">Name:</label>
  <input name="name" id="name">
    
  <label for="food">Choose a food:</label>
  <select name="food" id="food">
    <option selected disabled>--</option>
    <option>Apples</option>
    <option>Coconuts</option>
    <option>Chocolate</option>
  </select>
    
  <input type="submit" value="Send">
</form>

Pro: native implementations

Pro: native implementations

Con: customization limits

What can we do if the browser doesn’t let us override default styles?

Workarounds

Don’t fight the browser!

Be careful
when hiding labels

Relying on placeholders

.hide {
  display: none;
}
.hide {
  position: absolute;
  clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
  clip: rect(1px, 1px, 1px, 1px);
}
.is-hidden {
  position: absolute !important;
  clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
  clip: rect(1px, 1px, 1px, 1px);
}

Replace default focus state rather than removing it

Focus styles

Who it benefits

How it feels

Implementation 

 

Beyond the basics

Cross browser support

iOS number keypad

We can still do more!

What other ways can we help out our users?

Workflow

  1. Design
  2. Semantic HTML
  3. Test for a11y
  4. Add CSS styles
  5. Test again!

 

Example

Label text is 18px and bold

Is that okay?
Hire us link also fails

The End!

Resources

Thank you :)

Styling Forms Accessibly

By Amanda Cheung

Styling Forms Accessibly

Madison+ UX 2015

  • 4,548