2

Progressive disclosure defaults

 5 months ago
source link: https://adactio.com/journal/20999
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client

Progressive disclosure defaults

March 20th, 2024

When I wrote about my time in Amsterdam last week, I mentioned the task that the students were given:

They’re given a PDF inheritance-tax form and told to convert it for the web.

Rich had a question about that:

I’m curious to know if they had the opportunity to optimise the user experience of the form for an online environment, eg. splitting it up into a sequence of questions, using progressive disclosure, branching based on inputs, etc?

The answer is yes, very much so. Progressive disclosure was a very clear opportunity for enhancement.

You know the kind of paper form where it says “If you answered no to this, then skip ahead to that”? On the web, we can do the skipping automatically. Or to put it another way, we can display a section of the form only when the user has ticked the appropriate box.

This is a classic example of progressive disclosure:

information is revealed when it becomes relevant to the current task.

But what should the mechanism be?

This is an interaction design pattern so JavaScript seems the best choice. JavaScript is for behaviour.

On the other hand, you can do this in CSS using the :checked pseudo-class. And the principle of least power suggests using the least powerful language suitable for a given task.

I’m torn on this. I’m not sure if there’s a correct answer. I’d probably lean towards JavaScript just because it’s then possible to dynamically update ARIA attributes like aria-expanded—very handy in combination with aria-controls. But using CSS also seems perfectly reasonable to me.

It was interesting to see which students went down the JavaScript route and which ones used CSS.

It used to be that using the :checked pseudo-class involved an adjacent sibling selector, like this:

input.disclosure-switch:checked ~ .disclosure-content {
  display: block;
}

That meant your markup had to follow a specific pattern where the elements needed to be siblings:

<div class="disclosure-container">
  <input type="checkbox" class="disclosure-switch">
  <div class="disclosure-content">
  ...
  </div>
</div>

But none of the students were doing that. They were all using :has(). That meant that their selector could be much more robust. Even if the nesting of their markup changes, the CSS will still work. Something like this:

.disclosure-container:has(.disclosure-switch:checked) .disclosure-content

That will target the .disclosure-content element anywhere inside the same .disclosure-container that has the .disclosure-switch. Much better! (Ignore these class names by the way—I’m just making them up to illustrate the idea.)

But just about every student ended up with something like this in their style sheets:

.disclosure-content {
  display: none;
}
.disclosure-container:has(.disclosure-switch:checked) .disclosure-content {
  display: block;
}

That gets my spidey-senses tingling. It doesn’t smell right to me. Here’s why…

The simpler selector is doing the more destructive action: hiding content. There’s a reliance on the more complex selector to display content.

If a browser understands the first ruleset but not the second, that content will be hidden by default.

I know that :has() is very well supported now, but this still makes me nervous. I feel that the more risky action (hiding content) should belong to the more complex selector.

Thanks to the :not() selector, you can reverse the logic of the progressive disclosure:

.disclosure-content {
  display: block;
}
.disclosure-container:not(:has(.disclosure-switch:checked)) .disclosure-content {
  display: none;
}

Now if a browser understands the first ruleset, but not the second, it’s not so bad. The content remains visible.

When I was explaining this way of thinking to the students, I used an analogy.

Suppose you’re building a physical product that uses electricity. What should happen if there’s a power cut? Like, if you’ve got a building with electric doors, what should happen when the power is cut off? Should the doors be locked by default? Or is it safer to default to unlocked doors?

It’s a bit of a tortured analogy, but it’s one I’ve used in the past when talking about JavaScript on the web. I like to think about JavaScript as being like electricity…

Take an existing product, like say, a toothbrush. Now imagine what you can do when you turbo-charge it with electricity: an electric toothbrush!

But also consider what happens when the electricity fails. Instead of the product becoming useless you want it to revert back to being a regular old toothbrush.

That’s the same mindset I’m encouraging for the progressive disclosure pattern. Make sure that the default state is safe. Then enhance.

4:45pm

Tagged with css has selectors progressive disclosure enhancement frontend development defaults javascript electricity forms inputs checkbox checked pseudoclasses

Older »

Have you published a response to this? Let me know the URL:

Responses

Jon Lunman

@adactio Completely agree. Another analogy I like is the elevator vs escalator. If electricity fails, an elevator becomes useless. But an escalator just becomes stairs.

Also, the opposite of “display: none” isn’t always “display: block”. There could be other rules in the stylesheet that make it use “flex” or “grid”, perhaps at different breakpoints. So having the disclosure styles set “display: none” via “:not(:has(…))” is safer than the inverse.

# Posted by Jon Lunman on Wednesday, March 20th, 2024 at 5:01pm

2 Shares

# Shared by Giana ✨ on Thursday, March 21st, 2024 at 1:00am

# Shared by Ryan Townsend on Thursday, March 21st, 2024 at 1:01am

8 Likes

# Liked by Evil Jim O’Donnell on Thursday, March 21st, 2024 at 12:58am

# Liked by Tyler Sticka on Thursday, March 21st, 2024 at 12:58am

# Liked by Giana ✨ on Thursday, March 21st, 2024 at 12:58am

# Liked by John P. Green on Thursday, March 21st, 2024 at 12:59am

# Liked by Carlton Gibson 🇪🇺 on Thursday, March 21st, 2024 at 12:59am

# Liked by Jon Lunman on Thursday, March 21st, 2024 at 12:59am

# Liked by Ryan Townsend on Thursday, March 21st, 2024 at 12:59am

# Liked by nrk on Thursday, March 21st, 2024 at 1:00am


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK