Hawk's By Design

“Hey, can you make that nav stick to the top?”

“Can we have the left sidebar follow the screen as they scroll?”

“What do you think about having the sub-header stick as they scroll?”

Questions like these used to strike fear into my heart. No. Really. I used to genuinely be afraid of this. Why? Because it was a pretty decent amount of work to make this effect possible.

I’m not talking about a simple fixed displayed header, that’s easy. Although…that does tend to throw in some problems when you have auto scrolls…anyway. What I’m referring to are elements that are static, and then at some point as the user scrolls, switch over to a fixed positioning.

This used to involve a lot of work. Detecting where the element was in the viewport, listening for the scroll, finding out when the element should stop, BLEH! Luckily, CSS is pretty baller and there is a new way to do this easily.

Position Sticky

position: -webkit-sticky;
position: sticky;
/* top, bottom, left, or right declaration */

Personally, I like the name. It suits what it does.

If you add position sticky to an element, that element will toggle between position relative and fixed, based on the user’s current scroll position. The only requirement for this to work is to have at least one of the following properties along with it: top, bottom, left, or right.

This means that you no longer have to use javascript to calculate where on the page the user is, when will the element hit a certain threshold, or have a bunch of classes to toggle through based of the state of the element. In as little as two lines of css, you can make something appear static, yet follow the user as they scroll. Neat, right?

Let’s Practice

I would have to argue the most common implementation of this wicked feature would be to have a header, or nav, scroll with the user as they go through some content.

Let’s say we have three news articles, each with their own article title. We want the article title to scroll along with the user, so it stays in their sight, for as long as they are within that article. If we want it flush up against the top of the page, we can can do something like the following.

See the Pen Position Sticky Top 0 Example by Kyle Hawk (@Krazyhawk) on CodePen.

What if…you want the same effect, but you have your main navigation fixed to the top? Well, a slight change to the top property is all you need.

See the Pen Position Sticky Top 0 w/ Nav Example by Kyle Hawk (@Krazyhawk) on CodePen.

So you have a two column layout, and you want the left sidebar to follow the user? We can do that easily as well.

See the Pen Position Sticky Left Nav Example by Kyle Hawk (@Krazyhawk) on CodePen.

Browser Support

Here is the gotcha. Of course, right? Every cool thing has to have a gotcha.

Can I Use css-sticky? Data on support for the css-sticky feature across the major browsers from caniuse.com.

Browser support is not great, but it is getting better. If we look at support combined with webkit, then we are looking at about 86.91% support. Not bad, but could be better.

That’s why, when it comes to implementing this feature, it should be a progressive enhancement. That way, no worries if it’s not supported. Will your user die if the sidebar doesn’t scroll along with the viewport? Probably not. If they do, then maybe they should’ve updated their browser.


Position sticky is a great feature! Though I do wish support was better, it is in the category now where you can consider it a progressive feature and can rest assured a good portion of your audience is going to be able to utilize it.

Thanks for sticking through the article!

…okay that was bad.

Related Articles


February 16, 2021

Toggling Element’s Focus Outline Based On User Interaction

The focus outline adopted by every browser is a powerful tool for keyboard accessibility. It also, however, can be kind of annoying.

View post


February 15, 2019

You Know What? I’ll Say It. It’s Okay To Use jQuery.

It's okay to use jQuery or vanilla JavaScript! There, I said it. You don't have to use the latest and greatest framework. Do what's best for your project.

View post