Build Design Systems With Penpot Components
Penpot's new component system for building scalable design systems, emphasizing designer-developer collaboration.

medium bookmark / Raindrop.io |
Co-founder of Scrimba — a tool for creating interactive coding screencasts: https://scrimba.com.
The last few weeks I’ve been digging my head into CSS Grid and created a full course on the subject. And the more I learn, the more I’m convinced that this is the future of creating website layouts.
The course is 100% free, but you’ll have to authenticate with email or GitHub so that you can you can save notes and ask questions throughout the course.
And speaking of questions:
Throughout December I’ll be answering every single question that students ask inside the course.
Now let’s have a look at what you’ll learn and how you’ll learn it.
The course is built around three sections. The first two are linear and should be watched in order. They contain the CSS Grid concepts that I think are most important to learn.
The third one is a bonus section, in which you’ll learn concepts that didn’t make it into the first two sections plus see a couple of examples of things you can build with CSS Grid.
We’ll start with why you should learn CSS Grid. I’ll show you the benefits CSS Grid has over a framework like Bootstrap, comparing the code between the two approaches.
We’ll then jump straight into CSS Grid, starting with a very simple grid which will teach you how to define rows and columns, and the different values you can use to set the width and height. This will also teach you the basics of responsiveness.

The next step is to create a dummy website layout. Here you’ll learn how to position items in the grid. We’ll end the first section with an exciting experiment using the grid-template-areas property, which allows you to prototype layouts quickly.

At the end of section one you should know enough to start using CSS Grid in your personal projects. Here are the main concepts you’ll learn:
display: grid;grid-template-columns, grid-template-rowsgrid-template (shorthand)grid-column, grid-rowgrid-template-areasgrid-areagrid-gapfrTo get a gist of some of this section you can also check out my two articles Learn CSS Grid in 5 minutes and How to prototype websites quickly with CSS Grid. They touch upon a few of these concepts, though they don’t go as in-depth as the course does.
Here you’ll learn about advanced responsiveness. This will enable to create a super cool image grid at the end of the section:
Notice how the grid shuffles around on items to make it work regardless of the width.
As you can see, it varies the amount of columns according to the width of the screen size, and it shuffles around on the items (which have different sizes and shapes) so that there are no open spots.
Most of the magic happens in a single line of CSS. However that line of code is a bit complex, so we’ll go through every step of the way, so that you’ll fully grasp it.
Here’s what you’ll learn:
auto-fitrepeatminmaxgrid-auto-flowAt this point, you should be comfortable creating pretty much any layout using CSS Grid. And whatever concept you don’t know yet, you’ll be fully capable of finding out for yourself, as you have a strong core understanding of CSS Grid.
The final section is the bonus material. This doesn’t have to be watched in order, as the screencasts don’t depend on each other. This section consists mainly of various CSS Grid concepts which we couldn’t fit into the first two parts. However, you’ll also find a comparison between Flexbox and Grid, where I look at how the two modules differ and how they can be used together.
Plus, my co-founder Magnus will give you very cool example on how to recreate article layouts with CSS Grid:
Magnus will take your through building an article layout using CSS Grid.
Finally, we’re going to fill up this course with content whenever we see need for it.
If you feel something is lacking from the course, just tell us and we’ll create a new screencast on the subject in the bonus section.
Here’s what you’ll learn in the Bonus section.
The course is built using Scrimba, an interactive coding screencast tool which I’m a co-founder of, together with Magnus and Sindre.
Scrimba screencasts look like normal videos, however they’re fully interactive. You can edit the code inside the casts.
Here’s a gif which explains the concept:

Pause the screencast → Edit the code → Run it! → See your changes
This is great for when you feel you need to experiment with the code in order to properly understand it, or when you simply want to copy a piece of the code. Also, Scrimba screencasts weigh 1% of videos in file size, meaning that it’s much easier to stream even when your internet connection is slow.
So I really hope you’ll enjoy the course. Signup on the link above and I’ll see you there 🙂
AI-driven updates, curated by humans and hand-edited for the Prototypr community