Learn how to create a responsive CSS grid layout

Поделиться
HTML-код
  • Опубликовано: 12 янв 2025

Комментарии • 145

  • @nielslytzdk
    @nielslytzdk 3 года назад +102

    Kevin is best CSS teacher on RUclips. Period. It's an absolute delight watching his videos and you learn so much :)

    • @Allformyequine
      @Allformyequine 3 года назад +1

      AGREED!! I would probably have to stop my web development without his css help lol!

    • @webdev_am
      @webdev_am Год назад

      100% Agreed. For example when I need some tutorial in JS or React I search for random people but when it comes to CSS I know one place for sure it is this channel. Thank you Kevin for the job that you do for us 🔥🙌🏼

    • @westonjp612
      @westonjp612 Год назад

      By far! I found him on a css battle video and Ive learned more from him than I have in school.

  • @iLikeMyOwnPosts
    @iLikeMyOwnPosts 3 года назад +47

    Kevin, I just discovered you a few weeks ago and have been watching like crazy. I needed something just like this for a project I am working on this weekend. Perfect timing, happy new year!

    • @KevinPowell
      @KevinPowell  3 года назад +6

      Welcome aboard! Glad that you're enjoying my content!

    • @fernando-2160
      @fernando-2160 2 года назад

      Ahh hh hum hh

  • @WellSaint001
    @WellSaint001 3 года назад +15

    Man, you truly are a dev hero!!
    It feels weird that a couple months ago I didn't know about your channel, and now I'm trying hard not to miss any of your videos. Also, double thanks for letting us know more about css-grid.

  • @hcf797
    @hcf797 3 года назад +9

    Yes! Please do a video on optimization. I spend so much time trying to optimize, making different sizes for the same img, etc., that I’m sure there is an easier way. Thanks for all you do, Kevin.

  • @bobmarteal
    @bobmarteal 3 года назад

    The full outline of how to really use aspect-ratio makes me really happy.

  • @helenahan3628
    @helenahan3628 Год назад

    I am doing my homework and was stuck with the grid layout for the whole day, and then, I found your video! definitely saved me! thank you so much for this fantastic video.

  • @aaroonplay1993
    @aaroonplay1993 Год назад

    No doubt about it, every time i have struggled with css, this is the place to come. thanks a lot.

  • @asyncawaited
    @asyncawaited Год назад

    I subbed to your channel the moment I started watching some of your other videos. I must say you are a true master of CSS, but the thing that's so strikingly humorous and fun for me is the continual "we're going to fix that!" in your videos. I love how fun you make it and it's so refreshing to be able to chuckle and know that no matter how many times you break something for the sake of a good tutorial, it's going to get fixed; because you're a master of your craft. Thanks for making learning fun!

  • @jaydenmoon1165
    @jaydenmoon1165 3 года назад +3

    Kevin - dude, you are simply an amazing teacher - thank you so much for all your hard work - cannot wait to see what this year brings

  • @vasyaqwe2087
    @vasyaqwe2087 2 года назад

    I've watched so many of your videos now and with each new video I watch I keep thinking of how much I learn from you. Kevin, you're amazing. Please keep doing what you're doing.

  • @melbazany7417
    @melbazany7417 2 года назад

    You're truly the best. Bingeing your channel for the past few months. Sincerely, thank you!!!

  • @ngocanha85
    @ngocanha85 2 года назад

    Cant describe what you have openned my eyes, Kevin!!! Thank you so so so much!!!

  • @tedbailey6530
    @tedbailey6530 8 месяцев назад

    Love the video. I never really knew the ins and outs of grid. You nailed it. Thanks, Kev.

  • @junkboxrobots3309
    @junkboxrobots3309 8 месяцев назад

    Awesome, dude. Love the video. I had forgotten grid structuring in css and I love your explanations best. I'm going to watch your other stuff as well.

  • @ricardodesirat2590
    @ricardodesirat2590 3 года назад

    Seeing you so happy with grid makes me so happy :)
    Great video!

  • @CrazyCodingChannel
    @CrazyCodingChannel 3 года назад +1

    One of the best teachers I've seen

  • @outpost31737
    @outpost31737 2 года назад

    I'm a bit late with this but thanks Kevin I've just finished a big real world project for a client and this video nailed it for me!

  • @johny962
    @johny962 Год назад

    Thank you! Now I know grid-template-columns: repeat(auto-fit, minmax(x,y)) and aspect ratio better.

  • @davidsonfong9549
    @davidsonfong9549 2 года назад

    Kevin, I cannot thank you enough for all this wonderful knowledge that you’ve shared. You have helped me become such a better programmer. Thank you!!!

  • @patunolaibukun2506
    @patunolaibukun2506 Год назад

    😮Just discovered o haven't subscribed after week of watch your tuitorials, Kelvin you're a saviour to we beginners

  • @LogicalAmericanMuslim
    @LogicalAmericanMuslim 9 месяцев назад

    bro, you are awesome! I recently started building responsive pages and this video helped me alot! thank you

  • @Corvinade
    @Corvinade 3 года назад

    man, these videos are amazing. I thought I was a master at css grid but still learned a few new things in this video

  • @broadshare
    @broadshare 3 года назад

    Thank you Kevin, your channel is a web tool. Always learning new things from you

  • @lokecrafter7055
    @lokecrafter7055 Год назад

    Nice tutorial worked perfectly for creating a home page of apps

  • @AlokPrasad-q5w
    @AlokPrasad-q5w 4 месяца назад

    This video was exactly what i was searching for😆

  • @jeffreyhendrikfrans1479
    @jeffreyhendrikfrans1479 Год назад

    Thanks for the grid lesson Kevin. Help me so much 🙏🏼

  • @inweblife
    @inweblife 3 года назад

    Kevin, wish you all the best!

  • @VladimirosJohanson
    @VladimirosJohanson 3 года назад

    Kevin, first of all congratulations on your amazing work with your RUclips channel and your courses elsewere, you are an amazing teacher. On with my question now, where did you got this T-shirt, I want one too!

  • @riyatiwari7178
    @riyatiwari7178 2 года назад

    Thank you so much Sir for this tutorial, it saved my life.❤❤❤❤❤

  • @mahmoud-bakheet
    @mahmoud-bakheet 3 года назад +1

    I’m always watch your videos whatever that you’re providing , I hope you always be continued we love your videos and the way that you coding ❤️❤️

    • @KevinPowell
      @KevinPowell  3 года назад +2

      Thanks Mahmoud! I've got no plans to stop anytime soon!

  • @harshilmaheriya6374
    @harshilmaheriya6374 2 года назад

    Hands down for this legend 🙏🏻💯🙌

  • @rezarahman1782
    @rezarahman1782 3 года назад

    That was great. You have also focused on Aspect Ratio as well. Especial thanks for that.

  • @_slier
    @_slier 2 года назад +1

    man, nowadays is so easy to develop good looking website.. back then when im actively working as web dev, i still remember that designer need to use `table` to create some sort of layout.. then come along `float` that make everything much easier.. `grid` is even easier to use..

  • @NovaKirsch
    @NovaKirsch Год назад

    Merry Christmas, Kevin

  • @m.albehery
    @m.albehery 3 года назад

    one of the best videos I have ever seen

  • @5555Elenka
    @5555Elenka 3 года назад +2

    С рождеством и наступающим Новым годом Кевин ! Крепкого здоровья Вам и вашей семье ! Спасибо за уроки )С наилучшими пожеланиями !!! 👍👍👍🎅🐯🌲💥💥💥

  • @zertybee
    @zertybee 3 года назад

    Love all your videos, Im creating my own site and you help me out a lot!

  • @SaleKnezevic
    @SaleKnezevic 3 года назад

    So much excellent information here. Thanks!

  • @diviagency7532
    @diviagency7532 3 года назад

    To fix the grid on mobile, I usually wrap the display:grid in a min-width: 400px media query so the minmax() function won’t break the design on extra small screens. I won’t use multiple columns on small screens, so display block works just fine.

  • @luisdefreites4596
    @luisdefreites4596 3 года назад

    Hey Kevin your videos are awesome, thank you so much!

  • @petarkolev6928
    @petarkolev6928 3 года назад

    Kevin, thank you for the wonderful tutorial ❤️ You make me dominate my colleagues when it comes to CSS :D

  • @itzmebzb
    @itzmebzb 2 года назад

    Very helpful guide! Thank you

  • @PhilipJones
    @PhilipJones 3 года назад

    Thanks!

    • @KevinPowell
      @KevinPowell  3 года назад

      Thanks so much Philip!

    • @iLikeMyOwnPosts
      @iLikeMyOwnPosts 3 года назад

      Whoa! Awesome, Philip, thank you from the whole community :)

  • @Mast3rDesign
    @Mast3rDesign 2 года назад

    Just great vid :) Very useful and clear

  • @assoftTR
    @assoftTR 3 года назад

    Awesome! Thank you Kevin!

  • @shinmini99
    @shinmini99 Год назад

    Thanks for make this awesome video🔥🔥

  • @marcelopuppio7174
    @marcelopuppio7174 3 года назад

    El primer video que veo en 2022 :D thanks!

  • @narayadewe7979
    @narayadewe7979 2 года назад

    Amazing Teacher!!!

  • @AWM_2023
    @AWM_2023 3 года назад

    Grazie.

  • @not_amanullah
    @not_amanullah 10 месяцев назад

    This tutorial is helpful ❤

  • @lenarnie2973
    @lenarnie2973 3 года назад

    really nice video, i like ur content, we all need this to be better

  • @ArchAid1
    @ArchAid1 2 года назад

    This is soooooo AWESOME 🤩🤩🤩🤩🤩

  • @norvisnorvis7592
    @norvisnorvis7592 3 года назад

    My favorite developer. 🤗

  • @DaveSteinberg
    @DaveSteinberg 3 года назад

    Great demo. Thanks for creating it!
    One thing I noticed is that you're using an h2 but no h1, which is a bad thing for accessibility, since it breaks the semantic hierarchy of headings.
    If there's only one level of heading on your page, it should always be h1, and you can style that to be whatever size you want.
    If you're assuming that there would be an h1 above the grid on a "real page", then it would be helpful to say so explicitly, so that your viewers don't accidentally pick up practices that harm accessibility.

    • @daldreams
      @daldreams 3 года назад +3

      Kevin has done at least one other video about semantic hierarchy so there's really no need for him to address something that's part of the bigger picture and would take away from what he wants to cover in this particular tutorial.

  • @MartynKoi
    @MartynKoi 3 года назад

    Thanks for another great video. I wonder if you could make a video concerning the sizes / break points for different screens, there is so much information on the net, yet non of it is consistent and gets very confusing. Happy New Year and stay safe.

  • @ACharlar22
    @ACharlar22 2 года назад

    Thnks a lot for this, ur the best!

  • @ichhabahnung
    @ichhabahnung 3 года назад

    so simple, so clean, so nice :)

  • @LunaFolf
    @LunaFolf 3 года назад +1

    I’m not a mathematician, and this could be a happy coincidence, but in regards to the 1.25 aspect ratio on the feature card image - because the card is spanning the height of two cards, and the card aspect ratio is 1.5, I believe to calculate the correct aspect ratio would be the difference (0.5) to the power of the span (2).
    So (0.5)^2 would be 0.25, which is what you’ve put.
    I’m on mobile and haven’t tested this yet with other sizes, so I have no idea if this theory holds up lol.

    • @The-Dev-Ninja
      @The-Dev-Ninja 3 года назад

      what span mean in aspect ratio or grid? is the font-size?

    • @LunaFolf
      @LunaFolf 3 года назад

      @@The-Dev-Ninja I was referring to the grid column and grid row span

    • @bjornbergqvist776
      @bjornbergqvist776 3 года назад

      @@LunaFolf
      I did that maths kind of in the other way around. Since the big card takes up 2 columns, the aspect ratio is essentially is two units of length (let's call them fr as it's kind of similar), while the smaller cards is one unit of width. That gives us: 2fr*1.25 = 2.5fr
      and 1.5fr + 1fr = 2.5fr
      So 2fr * 1.25 = 2.5fr = 1.5fr + 1fr

  • @joelincz8314
    @joelincz8314 3 года назад

    Thanks, this is super useful!

  • @aryan7069_
    @aryan7069_ 3 года назад

    WOW , Thats great video man

  • @_loss_
    @_loss_ 2 года назад

    Another great one

  • @Zirpho
    @Zirpho 3 года назад +1

    One way to fix the issue with grid-template-columns breaking the layout at small sizes it to use for e.g:
    minmax( min(15rem, 100%), 1fr )
    This way the minimum column size won't overflow even att screen sizes smaller than 15rem.

  • @ՀայկԽաչատրյան-ը2խ
    @ՀայկԽաչատրյան-ը2խ 3 года назад

    You said you're moving from BEM. What naming system do you prefer now? Sorry, I'm not an old viewer. And btw, amazing video!

  • @radomirmijovic2605
    @radomirmijovic2605 3 года назад

    What keyboard are you using? Thanks for teaching us CSS!

  • @jonathonkiner7415
    @jonathonkiner7415 3 года назад

    That is some of the best most amazing CSS I've ever seen!! Too bad I can't use any of it since I'm learning to code for emails.

    • @Killyspudful
      @Killyspudful 3 года назад

      Tell us more of the fascinating details of your life.

  • @punkmonkeyKenpo
    @punkmonkeyKenpo 3 года назад

    what would you suggest for styling LOB design using component based frameworks like Blazor, Angular, VUE etc. ?

  • @badtwin82
    @badtwin82 3 года назад

    Mind: Blown 🤯

  • @rproctor83
    @rproctor83 3 года назад

    Is there some way in just CSS to take a random assortment of different aspect ratio image and realign them so that they are properly spaced apart with no dead space? Like take 4 square images and one tall image and having the tall image automatically span 2 rows height creating an even layout? Hard to explain in text.

  • @MyDpop
    @MyDpop 3 года назад

    *firebrick* is the color of the month 🎅

  • @magicsoka
    @magicsoka 3 года назад

    Great lesson, never used it like this before, really thank you Kevin.
    I have one question. What if I have two grids on top of each other, and each one has its own cards within it, how to make the same width for all the cards in the two sets?

  • @johnpauldelacruz5261
    @johnpauldelacruz5261 3 года назад

    I have a question, when you creating a layout do you practice this before you start the vlog or do you do this on the spot?
    Thanks im a new subscriber and i love your tutorials specially css grid.

  • @TheBorninmotion
    @TheBorninmotion 3 года назад

    great point thank you Kevin !

  • @Oluz1975
    @Oluz1975 3 года назад

    @Kevin Powell Hi, love the tutorial, what key combination are you using to select next occurrences? i herd crl+d but when i use the same combination it selects all instances with "card-xyz" not just the

    • @techjavaid6177
      @techjavaid6177 3 года назад

      First you need to select the card then keep on hitting ctrl + D to select all card classes

  • @Yeldarb1960
    @Yeldarb1960 3 года назад

    I've gone brain dead. In a responsive grid with an odd numbered equal sized "cards" or divs, when the screen begins to get smaller and the cards shift to a new row how can you make that or those cards become centered rather than justified left? Thanks in advance. Great video. I've learned a great deal from you.

  • @philkewley
    @philkewley 3 года назад

    this is the layout that I've wanted for my clothing store - because it's got a comic book style and that's the sort of timid approach to anarchy that I am comfortable doing. And it looks so good! But then I also managed to break something, I was putting it all together on a 2560 x 1289 monitor and I started fiddling with the grid size & aspect ratio until it stopped looking bloated, then I uploaded to check it on my ancient oneplus (6 I think) phone, looks great. smaller iPhone 12 looks even better! - but then It gets messed up on the iPad AIR at 820 width because it pulls the card content div 100% on top of the image. I am super scared of fiddling with it any more because on an iPad Pro it looks perfect at both 1024 & 1366. How far do you go for perfection? I wish I was more confident and could hold knowledge the way you do, you make it look so easy!

  • @bluesky-vc3tk
    @bluesky-vc3tk 2 года назад

    hello kevin im a beginner in this field when i saw the predefined ccs rules im really confused because there are alot of things i dont know and didnt use

  • @daldreams
    @daldreams 3 года назад

    Awesome!!! You ROCK!! :)

  • @kribo9604
    @kribo9604 2 года назад

    Grid area's is my thing now

    • @kribo9604
      @kribo9604 2 года назад

      ok learnt you can declare both grid-template-columns and grid-template-rows at the same time, cool
      Get both rows and columns setup gives more grid-area control, cool

  • @pedro2lavega
    @pedro2lavega 2 года назад

    I'm a big fan of your tutorials and I like the way you handle css, but I get a little frustrated about semantic.
    For instance, when you create a card, shouldn't you be using figure, img and figcaption ?
    I think it'd be more efficient as far as accessibility is concerned, am I wrong ?

  • @strelock-youssef
    @strelock-youssef 3 года назад

    great course
    i sometimes when i use grids and creat a cards layout i ancounter a card that dont have a picture and that ruins the overall style of cards
    is there a way to make the text and button maybe to be always at the bottom regardless if the card have a picture or not

    • @KevinPowell
      @KevinPowell  3 года назад

      With this approach that would happen, with how I've set up the alignment of the content.

    • @strelock-youssef
      @strelock-youssef 3 года назад

      @@KevinPowell i ll try it on my project thanks for the great content

  • @user-yf1ml8jt3i
    @user-yf1ml8jt3i Месяц назад

    there ought to be a flow diagram that explains when to use flexbox over css grid

  • @raj080288
    @raj080288 2 года назад

    Grid isn't supported in ie10 and 11 though? How can we cater for these browsers?

  • @zbigniewiksinski
    @zbigniewiksinski 2 года назад

    why would you put container in rem values?

  • @bokistotel
    @bokistotel 2 года назад

    Does repeat(auto-fit,minmax(15rem, 1fr)); removes necessity for @media (min-width:...) ?

    • @KevinPowell
      @KevinPowell  2 года назад

      For some layouts, it sure does :). We still need media queries, but not as much as we used to.

  • @karuheine1152
    @karuheine1152 3 года назад +1

    What does API by day, IPA by night mean? Just curious.

    • @KevinPowell
      @KevinPowell  3 года назад +3

      APIs are used in development, and IPAs are a type of beer 🙂

    • @karuheine1152
      @karuheine1152 3 года назад

      @@KevinPowell 😂😂😂

  • @lapridagaspar
    @lapridagaspar 3 года назад

    Is there a way to use grid-template-columns auto-fit with a px min value and a max amount of columns? Say I wanna push columns to the next row if they don't fit but I don't wanna have more than 4 columns (even if a fifth one fits)

    • @lapridagaspar
      @lapridagaspar 3 года назад

      using minmax(100px,25%) with GAP makes the last column NOT to fit (and leaving a weird empty space)

    • @KevinPowell
      @KevinPowell  3 года назад

      No way to limit the total columns, other than limiting the width of the grid container.

    • @lapridagaspar
      @lapridagaspar 3 года назад

      @@KevinPowell I actually figured it out!
      This is what I did:
      .grid{
      --gap: 20px;
      --max-cols: 4;
      --min-col-width: 150px;
      --grid-cols-min: max( var(--min-col-width) , calc( (100% / var(--max-cols) ) - (var(--gap) * (var(--max-cols) - 1) / var(--max-cols) ) ) ); //explanation below
      display:grid;
      gap: var(--gap);
      grid-template-columns: repeat(auto-fill, minmax( var(--grid-cols-min,0), 1fr ) );
      }
      //explanation
      max( var(--min-col-width), calc( 100% / var(--max-cols) );
      //this would have been enough if it wasn't because of the GAP. That's why I needed the other part.
      //if I have 4 columns, that means I have 3 gaps, and thats what the calc() does.

  • @wwhill8033
    @wwhill8033 3 года назад

    Excellent thanks

  • @johnnydragovic6892
    @johnnydragovic6892 3 года назад

    I liked the video, it is very useful. Is there a video that explains the units of measurement in css like rem px.........

    • @KevinPowell
      @KevinPowell  3 года назад +2

      ruclips.net/video/N5wpD9Ov_To/видео.html 😁

    • @johnnydragovic6892
      @johnnydragovic6892 3 года назад

      @@KevinPowell Thank you 😁😁😁😁😁😁

  • @asdfafafdasfasdfs
    @asdfafafdasfasdfs 3 года назад

    Hi Kevin, could you please make a video about Tailwind? Seen many positive comments + approach combining it with PostCSS (supposedly to help with the "class mess" / to create semantic classes. Also what are the pros and contras compared to e.g. SCSS. 🙏

    • @KevinPowell
      @KevinPowell  3 года назад

      I'm not a big fan of Tailwind, so no plans for content on it 🙂

    • @asdfafafdasfasdfs
      @asdfafafdasfasdfs 3 года назад +1

      @@KevinPowell You also could trash it haha. Just to get an idea of how it compares. Some of us hear about it constantly and don't know it so it would be interesting. But totally fine if you don't!

  • @_rohit_s
    @_rohit_s 3 года назад

    (?) You know difference between
    { padding-inline-start and padding-left }
    hard to find difference maybe related to { writing-mode } can you help a little

  • @ahsath
    @ahsath 3 года назад

    Hahaha the laugh after the magic numbers, he knows

  • @Tomtoptuts
    @Tomtoptuts 3 года назад

    Love you Kevin 🤗🇧🇩

  • @not_amanullah
    @not_amanullah 10 месяцев назад

    Thanks ❤

  • @gestaltlabart
    @gestaltlabart 3 года назад

    Awesome!

  • @emmyleke7049
    @emmyleke7049 3 года назад

    Beautiful

  • @starsabove
    @starsabove 2 года назад

    Thank you!

  • @hani4239
    @hani4239 3 года назад

    Idk why but watching this whole video was Oddly Satisfying...

  • @nomadshiba
    @nomadshiba 2 года назад

    i don't think you need aspect ratio here
    you can just use height: calc(100% - 1em) or something like that

  • @Denvercoder
    @Denvercoder 3 года назад

    Are those Sennheiser 560s?

    • @KevinPowell
      @KevinPowell  3 года назад +1

      I forget the model as I'm not on my computer right now, but that sounds right 🙂

  • @narayadewe7979
    @narayadewe7979 2 года назад

    22:41 card featured