How to Write Better Containers in Tailwind CSS
Throughout HyperUI you will see the classes max-w-screen-xl mx-auto px-4
used to contain content, this can be seen on the website and the components.
Some of you may be wondering...
Why not use the
.container
class?
Great question.
Let's look at the .container
class documentation on the Tailwind CSS website.
As we can see it provides max-width
sizes at different breakpoints, which results in the content within the container snapping to that size as the breakpoint is reached.
If you shrink/expand the preview you will see the content within the container snapping.
A More Fluid Container
Here's the same preview but using the classes I mentioned at the start of this blog post.
As you can see it's more fluid, you reach the breakpoint where max-w-screen-xl
is no longer applied and then the padding is used to contain the content. If you wanted a fully fluid container you can remove the max-w-screen-xl
class.
Let's compare the two.
An argument for the .container
approach is that the content is wider on larger screens, but to solve that you can use max-w-screen-2xl
instead of max-w-screen-xl
.
Edit the Config and Write Less Code
One final note, if you are using the .container
approach and find yourself writing container mx-auto
a lot, then you can do the following.
theme: {
container: {
center: true,
// Optional
padding: {
DEFAULT: '1rem',
sm: '1.5rem',
lg: '2rem'
}
},
}
Fun fact, I wrote a blog post in 2021 arguing the .container
approach over using max-w-screen-xl
, you can still read that.