Making scrollable sections snap

โœ๏ธ

How to make scrollable sections snap to the top with CSS

21 Mar, 2021 ยท 2 min read

I created this cool section scroll in Tailwind. However, I would almost expect the sections to snap while I'm close to them as a user.

So today, I'll show you how to make the sections snap!

You can try it out on the following Codepen.

See the Pen Making scrollable sections snap by Chris Bongers (@rebelchris) on CodePen.

Making the sections snap with CSS

Let's use the code as we had previously. However, we will need to change a couple of things.

First of all, our current wrapping container for the sections has an infinite height, meaning it will become as big as the children are.

For the scroll snap to work, it must be as big as the screen.

Change the following:

<div class="w-full ml-auto md:w-5/12"></div>

Into:

<div class="w-full h-screen ml-auto overflow-y-auto md:w-5/12"></div>

We add the h-screen class, which will make this section exactly our viewport height. We also add overflow on the y-axis to auto.

That's already half the work. Now let's add the scroll-snap magic.

Old: Unfortunately, Tailwind does not come with these classes. For the ease of this tutorial, I'll add two custom classes.

Tailwind V3 now comes with scroll snap classes, so let's add the scroll snap behavior we want on the parent element.

<div
  class="w-full h-screen ml-auto overflow-y-auto md:w-5/12 snap-mandatory snap-y"
></div>

We used snap-mandatory to define how the snapping should behave and the axis on which it acts, which is snap-y for our demo.

Then we need to add a class to each section to define how it snaps to the parent. In our case, we want it to snap to the top.

<div
  class="flex flex-col items-center justify-center h-screen p-10 bg-red-200 snap-start"
>
  <h2 class="mb-5 text-4xl">Meet Benny</h2>
  <p class="mb-5">I was born 20 May 2020</p>
</div>

This tells the scroll-snap where to snap to. In most cases, you'd like the start. It will snap the element to the top of the scroll-snap container.

However, you can also choose between: end, center, or none.

And that's as simple as it gets.

Browser support

Surprisingly enough, scroll snap has excellent support and can be safely used!

CSS Scroll-snap support

Thank you for reading, and let's connect!

Thank you for reading my blog. Feel free to subscribe to my email newsletter and connect on Facebook or Twitter

Spread the knowledge with fellow developers on Twitter
Tweet this tip
Powered by Webmentions - Learn more

Read next ๐Ÿ“–

Bringing perspective to CSS

7 Aug, 2022 ยท 2 min read

Bringing perspective to CSS

Creating a 3D Cylinder shape in CSS

29 Jul, 2022 ยท 3 min read

Creating a 3D Cylinder shape in CSS