CSS Grid is the new layout standard for the web, but we still are just getting started with new layout ideas. Many assume that CSS Grid is just a replacement for table layouts, but that’s simply not true. Others might think that we can use CSS Grid to replicate more advanced print layouts, which brings us closer to what’s possible.
One of the main reasons behind the idea of the CSS Grid Challenge was to have some starting points for layouts, and show what can be achieved with CSS Grids today. Well, we received some many great submissions that it was really hard to choose the one winner — there are so many submissions who deserve to win first place.
While the browser support for CSS Grid is really good already, it isn’t supported in the older browser versions. That’s why we challenged you to implement fallbacks for browsers that don’t support CSS Grid just yet, and most of the submissions were doing fine in that regard. Falling back to floats and Flexbox isn’t hard, but still not all submissions were providing fallbacks for browsers that don’t support CSS Grid. We had to deduct some points in these cases, unfortunately.
So without a further ado, let’s look at the submissions which we think are the most impressive ones:
? The Winner Of The CSS Grid Challenge 2017 Is… James Clarke!
James Clarke’s CSS-only The Deck (download the template, ZIP, 1.3MB) is particularly well suited for a linear narrative that you might find in presentations or marketing pages. What we think was particularly interesting is the cross-horizontal way to navigate between the different pages. Also, we like the use of lots of whitespace, so that the focus of each page remains perfectly obvious.
Please keep in mind: This template isn’t keyboard-accessible and we’re working with James to improve it.
data:image/s3,"s3://crabby-images/3939f/3939f900582bfbee2ca3e2244eea1054dc5b1ead" alt="The Deck by James Clarke"
On smaller devices, the template turns into a regular layout, and it falls back graciously on browsers that don’t support CSS Grid. Ladies and Gents, a big round of applause for the winner of the CSS Grid challenge!
Insights from James himself:
"As CSS grid layout is new technology and sits atop many other advances that have been built into CSS, I chose to limit myself to see what I could build with HTML and CSS alone. I elected to rebuild an old website from about 10years ago that was built using the then-popular "MooTools" javascript library. That library opened up the ease of cross-browser javascript development at the time, and the advance in CSS's capabilities seemed to offer a similar possibility. The result of my efforts I call "Deck". It is a format that is particularly well suited to the sort of linear narrative that you might find in a power-point presentation, or marketing pages. The standard these days is a long-scrolling page. That format works well of course, but it is undifferentiated, and we've been stuck with it for years now. I wanted to explore something a bit different, in hopes of finding a new way." Features: CSS only, no javascript. All interactions flow from native browser functions and CSS pseudo-selectors like :checked, :target. CSS Grid Layout: horizontal and vertical positioning, source re-ordering, adaptation to different viewports. Progressive-enhancement, responsive layouts: Smaller screen devices and older browsers receive a format catered to their needs and technologies. Touch friendly: All UI functions play well with touch-screen laptops/tablets/phones. Back/Forward button navigation: Back and forward buttons remain functional where browser support exists (current issues with MS Edge repainting when not initiated by javascript 'hash-change' event).
But Wait… There’s More!
We received a number of really impressive submissions and so we decided to give out a silver as well as a bronze medal, too!
? Second Place: Frida Nyvall
The second place goes to The Daily Prophet, a fictional newspaper for wizards built with Grid. It’s a great example for multi-column layouts that respond to smaller screen sizes. You can tell that the creator put a lot of effort into building this page with its subtle animations, using CSS Shapes, and a very thoughtful transformation of layout throughout all the different screen sizes. The only downside here is that the submission is not working in browsers that don’t support CSS Grid.
data:image/s3,"s3://crabby-images/8efbb/8efbb81d3b6b9e84f1429046d49d22bd5a576fe5" alt="A screenshot of the Daily Prophet, a phantasy, multi-column layout website built with CSS Grid"
data:image/s3,"s3://crabby-images/0dd04/0dd04379bd01c5136503fa47f89d56136cfd45e1" alt="CSS Grid by Victor Janin"
The winners have already been contacted. For those who didn’t receive an email from us — please stay tuned! We’ll be launching another challenge very soon!
Other Submissions
Again, we’re sorry that we only had to choose a limited amount of winners, and want to thank everyone who participated in this challenge — we sincerely appreciate your time and efforts! Another round of applause for the rest of the talented participants and their submissions:
Sam Beckham
Sam Beckham is a fan of Penguin Books and their marber grid. His CSS take on the subject lets you change the colors, font sizes, and everything else you fancy on individual books using BEM notation. You can also view a version that works in IE8 (apart from the SVGs) here.
data:image/s3,"s3://crabby-images/11078/1107898f5e3f9caa9349aa2afe160e020be8ded5" alt="CSS Grid by Sam Beckham"
Ren Aysha
A thumbnail presentation with CSS Grid, inspired by Polygon.com’s bevel treatment on some of their thumbnails. Older browsers get a fallback with a conservative thumbnail look instead. Apart from her contest submission, you’ll find more CSS Grid experiments on Ren’s CodePen.
data:image/s3,"s3://crabby-images/e5d1e/e5d1eb8cda8e727150c16464f377527ac742d27d" alt="CSS Grid by Ren Aysha"
Trang B. Nguyen
This layout features some lovely sea creatures, a bottom navigation, as well as an different way to navigate through the various sections of the site. Also, it falls back really good in browsers that don’t support CSS Grid.
See the Pen CSS Grid Layout by Trang B. Nguyen (@Trangbnguyen) on CodePen.
data:image/s3,"s3://crabby-images/821f4/821f440e6adf014a51ff85ecd2ceb1e256502d31" alt="CSS Grid by Charles Sejikco"
Dannie Vinther
A Marvel poster made with CSS and Clip-path. A sprinkle of JavaScript helps avoid layout reflow when images are fully loaded.
data:image/s3,"s3://crabby-images/02dd0/02dd0a6141aa70732c3c623d308b915fd596c7cf" alt="CSS Grid by Dannie Vinther"
Erik Davidsson
A great one for football fans! A layout featuring the upcoming football game between FC Barcelona and Real Madrid. Erik brought it to life with many different techniques with fallbacks to make the website usable in older browsers such as IE8 and IE9.
Resources and References
Ever thought of building an interactive cookbook with CSS Grid? Marissa Douglass did.
data:image/s3,"s3://crabby-images/8a507/8a507e6901c11f82c2c143b11a1983049ba6596c" alt="CSS Grid by Marissa Douglass"
Melissa Bogemanns
A photo showcase made with CSS Grid. Available as .zip (6MB)
data:image/s3,"s3://crabby-images/75fd6/75fd628c05675754770664386bc63dcf197bad6b" alt="CSS Grid by Melissa Bogemanns"
Tyler Argo
Tyler Argo re-built the Google Play Store layout from scratch using CSS Grid with fallbacks. It works all the way back to IE9 and is even more responsive than the original site.
data:image/s3,"s3://crabby-images/0dc27/0dc27d1942989c87ab6625819c5007eb4e4b623a" alt="CSS Grid by Tyler Argo"
Mauricio Mantilla
This layout is based on a website that was designed by the company where Mauricio works at. He took part of the layout, which is based on Packery (Masonry) and port it to grid with just a few lines of CSS Grid.
data:image/s3,"s3://crabby-images/8a8cb/8a8cb7204aaa9714ee38319680ae6a7ec20a3b06" alt="CSS Grid by Mauricio Mantilla"
Katherine Kato
A portfolio website layout made with CSS Grid and Flexbox as a fallback.
data:image/s3,"s3://crabby-images/935cc/935cce3c0a35aff4b8d5172e3d36df4158fff632" alt="CSS Grid by Katherine Kato"
Donny Truong
A minimalistic blog layout comes from Donny Truong.
data:image/s3,"s3://crabby-images/66270/662703c80bca9de55b7e416ec72657aa80dab99f" alt="CSS Grid by Donny Truong"
Anenth Vishnu
A responsive app layout based on Grid.
data:image/s3,"s3://crabby-images/60aac/60aac4c7465137dff9865261e63d38e598ea37c7" alt="CSS Grid by Anenth Vishnu"
Amy Carney
A basic layout (with IE fallbacks and web accessibility in mind) that may be useful for getting projects started or migrated.
data:image/s3,"s3://crabby-images/658a4/658a485eb00fcf5eed374b0ae3dcb68eecdc8a8c" alt="CSS Grid by Amy Carney"
Nurçin Özer
Nurçin Özer submitted a basic blog layout.
data:image/s3,"s3://crabby-images/4397d/4397d095140c760d60ee4cda89953f9ad0641457" alt="CSS Grid by Nurçin Özer"
Remy Oleszczuk
Inspired by the BBC SPORT landing page.
data:image/s3,"s3://crabby-images/d64ff/d64ffb1730467dd4cdbf3eeb7838595c32c19f31" alt="CSS Grid by Remy Oleszczuk"
Patryk Kalwas
data:image/s3,"s3://crabby-images/5e814/5e814d29533d2837145a204b8bfa338117ceb404" alt="CSS Grid by Patryk Kalwas"
Jesús Olazagoitia
data:image/s3,"s3://crabby-images/fa34a/fa34a5dbf887523391f534fccf80bac7043850cd" alt="CSS Grid by Jesús Olazagoitia"
Dóra Pölöskei
data:image/s3,"s3://crabby-images/7e20c/7e20c078ae8a565bc6c74de519cbfe7842592007" alt="CSS Grid by Dóra Pölöskei"
Vivek Singh
data:image/s3,"s3://crabby-images/47721/47721ae5a3d0298e9147fb796aabde7be1b231a8" alt="CSS Grid by Vivek Singh"
Pranjal Nadhani
data:image/s3,"s3://crabby-images/75478/75478fcd302fd75c54e3f36e400fc772274b5c91" alt="CSS Grid by Pranjal Nadhani"
Mathias Herrebaut
data:image/s3,"s3://crabby-images/04e2d/04e2d686915c38891ac7220e4483de1cc42d64eb" alt="CSS Grid by Mathias Herrebaut"
Noel Tekiri
data:image/s3,"s3://crabby-images/ec127/ec127dee24e832459db51ba4fe2a864fffdf6216" alt="CSS Grid by Noel Tekiri"
Aurélie Deschacht
data:image/s3,"s3://crabby-images/849c1/849c1420a9db8d2fa4e53191f855b26ef023b8d6" alt="CSS Grid by Aurélie Deschacht"
Jonathan Harrell
data:image/s3,"s3://crabby-images/82ea1/82ea191de7ab05447efb60a69308ef73839efb6c" alt="CSS Grid by Jonathan Harrell"
Getting Started With CSS Grid
Last but not least, before you dive right into the challenge, here are some helpful resources to kick-start your CSS Grid adventure.
Resources and References
- Grid Garden: A game for learning CSS Grid
- GridBugs: A community-curated list of bugs, incomplete implementations and interop issues
- Awesome CSS Grid: A manually curated list of CSS resources
- Grid by Example: Examples, videos and other information to help you learn CSS Grid Layout
- Rachel Andrew’s Grid Guide: the complete guide to Box Alignment, Flexbox, and Grid
- CSS Grid Layout: Examples, references and guides by the Mozilla team
- Chrome CSS Grid Highlighter: a little Chrome extension that highlights CSS grids.
Demos
- Jen Simmons’ CSS Grid Demos: Demos and examples of how Grid works
- CSS Grid Layout on CodePen: A collection of layouts built with CSS Grid
Tutorials
- Building Production-Ready CSS Grid Layouts Today by Morten Rand-Hendriksen
- Progressively Enhancing CSS Layout by Manuel Matuzović
- Getting Started With CSS Grid by Chris Brandrick
Talks
Inspiration
Finally, to get your ideas flowing, some inspiring CodePen experiments that illustrate the magic of CSS Grid:
data:image/s3,"s3://crabby-images/ff8bf/ff8bfbd0519acc7b188bc5d91aaf281082575759" alt="Responsive Magazine Layout"
data:image/s3,"s3://crabby-images/91314/91314f0f47a1162b3dcb4b34efa33b625e7f2e86" alt="Minimalistic CSS Grid Layout"
data:image/s3,"s3://crabby-images/f0c51/f0c51d4ce4fab7a10826763a579a60e3d9ac0762" alt="CSS Grid Layout and Comics"
data:image/s3,"s3://crabby-images/a407b/a407b6d67fc173fae1dfd57eee0ec41f537ff6d5" alt="Auto Hexagonal CSS Grid Layout"
data:image/s3,"s3://crabby-images/432c3/432c3900a5f0f5de2cfe0726b323802eb022d389" alt="CSS Grid Layout with @support Flexbox Fallback"
data:image/s3,"s3://crabby-images/1dfc2/1dfc235eb7e950a5a6f8ce1721b3452a8d89f980" alt="Image Areas in CSS Grid Layout"
data:image/s3,"s3://crabby-images/ad992/ad9929b188206e06500487432774daebec30cbfe" alt="Mondrian Art in CSS Grid"
data:image/s3,"s3://crabby-images/b480b/b480bc7dec9445dfc4452bb34b2ba9d74319a898" alt="CSS Grid Layout Slideshow"
Are You Ready For The Next Challenge?
That’s right! There will be more challenges coming up very soon, and even more prizes to win! Keep an eye on the magazine or follow us on Twitter so you don’t miss out next time.
data:image/s3,"s3://crabby-images/a7f1f/a7f1f75df7fba1aa30bdcc7bc3eda97dd613ddde" alt="Smashing Editorial"