Now, let's dive into each of the pseudo-elements and their customization possibilities. As mentioned previously, this will work for Google Chrome and Microsoft Edge browsers. This will also work in Safari desktop browsers with the -webkit
prefix. We'll discuss Firefox a bit later.
The below code samples will use the same CSS rules from the image you saw above so you can get a clear understanding of how the CSS pseudo-elements and properties tie together visually and written out.
::-webkit-scrollbar
The entire scrollbar container. Here, you can determine the width of a vertical scrollbar container and height of a horizontal scrollbar container. You can define both sizes in a single definition:
::-webkit-scrollbar {
width: 24px;
height: 24px;
}
::-webkit-scrollbar-button
The buttons of the scrollbar. The scrollbar buttons are not shown by default in most modern browsers but are something you can add for extra navigation control. The user can click one of these buttons to move a small amount of pixels up or down the screen.
The buttons were a feature more prominently used in the old days of internet browsing. Scrolling is more easily accomplished with the scroll wheel on your mouse nowadays, but the option is still available for websites that wish to show the extra controls.
You can either configure the buttons to display a single up and down button in the scrollbar: The up button above the scrollbar thumb, and the down button below it:
::-webkit-scrollbar-button:single-button {
/* single button styling */
}
Or you can customize to have the up and down buttons grouped together, once above the scrollbar track, and once below it:
::-webkit-scrollbar-button:double-button {
/* double button styling */
}
Additionally, you can add arrows to your scrollbar buttons so users know how to navigate through your content. The below code snippet shows an example of how you can scroll using an up and down button in a vertical scrollbar using simple CSS definitions:
::-webkit-scrollbar-button:single-button:vertical:decrement {
border-color: transparent transparent #9b6a2f transparent;
}
::-webkit-scrollbar-button:single-button:vertical:decrement:hover {
border-color: transparent transparent white transparent;
}
::-webkit-scrollbar-button:single-button:vertical:increment {
border-color: #9b6a2f transparent transparent transparent;
}
::-webkit-scrollbar-button:single-button:vertical:increment:hover {
border-color: white transparent transparent transparent;
}
Each of the values in the border-color
property represents a side of the button in which you want to show a different color. Square buttons will show a triangular arrow if you specify a color in a single side, like in the code sample above.
::-webkit-scrollbar-thumb
The draggable scrolling handle. If you click and hold this handle with your mouse cursor, you can drag the scrollbar thumb up and down in a vertical scrollbar, or left and right in a horizontal scrollbar, and the page will scroll with the movement of your mouse. Releasing the mouse button will stop the scroll animation.
::-webkit-scrollbar-thumb {
border: 6px solid #9b6a2f;
background: #e89a3e;
border-radius: 12px 12px 12px 12px;
margin: 0px auto;
}
::-webkit-scrollbar-track
The track of the scrollbar. This acts as a progress bar, showing how far down, or across, in the web page you are.
In this portion of the scrollbar, we'll simply set the background color so we can differentiate the actual draggable scrollbar node from its background track:
::-webkit-scrollbar-track {
background: #9b6a2f;
}
::-webkit-scrollbar-track-piece
The part of the track that's not covered by the thumb. I generally set this to the same color as the web page like the code snippet below. But it's your site that you're building, so play around with this and do what's best for your design aesthetic.
::-webkit-scrollbar-track-piece {
background: #9b6a2f;
}
::-webkit-scrollbar-corner
The bottom-right corner of the scrollbar, where both vertical and horizontal scrollbars meet.
Since I generally don't allow horizontal navigation on any of my websites (I just feel it's bad design practice to do so), I generally hide this from view. But you can also set it to any background color you like:
::-webkit-scrollbar-corner {
background: #9b6a2f;
}
::-webkit-resizer
The draggable resizing handle that appears in the bottom-right corner of some elements, like textarea
elements. The styling for this works similarly to the ::-webkit-scrollbar-corner
pseudo-element, so the same example above should work here, as well.
You can dive deeper into each of the pseudo-elements rules by adding additional pseudo-class selectors. We used a few of these in the examples above, so let's break down each of the options available:
Firefox doesn't have any advanced styling methods like Google Chrome or Microsoft Edge browsers. However, you're still able to customize scrollbar width, as well as thumb and track color.
Here's an example showing the two properties in action.
html {
scrollbar-width: auto;
scrollbar-color: #15171d #0d0f13;
}
Note that the properties are wrapped in an html
element selector. This is standard for Firefox scrollbar styling. If you want to styling specific elements with a horizontal or vertical overflow, then you can do so by changing the element selector to your liking.
You can also hide a browser window or child container's scrollbars with either of the following CSS rules:
overflow-x: hidden;
overflow-y: hidden;
overflow-x
hides the horizontal scrollbar and overflow-y
hides the vertical scrollbar.
To hide both vertical and horizontal scrollbars within a container with only one line of code, you can use the overflow
property:
overflow: hidden;
In this example, you've learned how to style scrollbars using CSS with a variety of different examples broken down into each piece of the scrollbar element.
Experiment and have fun with it! There are a lot of different styling methods you can use for scrollbars with CSS, and playing around with the different pseudo-classes, selectors, properties calls for a whole new level of excitement with CSS.
Written by: Josh Rowe
Last Updated: April 19, 2022