Debug panel

Close debug panel
Roma’s Unpolished Posts

Never Use “Scroll” Value for Overflow

Published on:
Categories:
CSS Overflow, CSS Tip, CSS 55
Current drink:
Camomile tea

This post is prompted by the website for the new “monaspace” family of fonts (it was fixed since I started to write my article — nice!)

The Problem

The problem there is the scroll value for any of the overflow properties. Don’t use it.

What you want to use instead in 99.9% of cases is the auto value.

Here is a screenshot of the issues from the “monaspace” website:

A screenshot of the stylistic set lists from the Monaspace website

In the above screenshot, there are only two blocks with actual scrollbars: on the bottom right, but every other similar element that does not have enough content for an overflow to happen still has a rectangle in the scrollbar’s place.

This is because the developers did use the scroll value, and did not test with the “Show scroll bars: Always” preference.

Here it is in the macOS “Appearance” System Settings tab:

A screenshot of one “Show scroll bars” settings in macOS

The default value for macOS there is “Automatically based on mouse or trackpad”, making most of the scrollbars everywhere to have the “overlay” styles.

Changing this setting to “Always” makes it easy to spot this mistake. Highly recommend.

The Solution

Just use the auto value.

But What If…

Do you need to reserve some space for the scrollbar? Ok, maybe then you’re excempt from this rule! As with anything, if you know absolutely what you’re doing — go for it.

Though, in the future, I would recommend using the scrollbar-gutter property with the stable value instead. Or, if you, for some reason, don’t need Safari support, you can go ahead and use it now.

Prevention

I did add this as a Stylelint rule to our codebase.

The rule I did chose for this is declaration-property-value-disallowed-list:

{
	rules: {
		'declaration-property-value-disallowed-list': [
			{
				'/^overflow(-(x|y|inline|block))?$/i':
					/\bscroll\b/i,
			}
		]
	}
}

That’s it! If you’re using Stylelint — I recommend adding this rule yourself. If you’re not — I’ll strongly recommend starting using it, especially if you’re working in a team.

Please share your thoughts about this on Mastodon!