Simple solutions to responsive typography

Поділитися
Вставка
  • Опубліковано 19 січ 2025

КОМЕНТАРІ • 229

  • @MilanRegec
    @MilanRegec 3 роки тому +67

    So glad to see Kevin now includes accessibility concerns in every video he makes. This is so important for the community. Thank you!

    • @miyalys
      @miyalys 3 роки тому

      @avfr like derek banas? anyway who hurt you?

    • @TuringTested01
      @TuringTested01 2 роки тому +4

      @@miyalys a blind guy with hearing issues took his girlfriend and now he's sad

    • @throwbacksfather6625
      @throwbacksfather6625 2 роки тому +1

      @avfr what the hell is a soydevs

  • @technikhil314
    @technikhil314 3 роки тому +76

    That +1rem is noiceeee I love it. Pinch zoom is issue with viewport units.

    • @thecashewtrader3328
      @thecashewtrader3328 3 роки тому +1

      this

    • @PaulMcCannWebBuilder
      @PaulMcCannWebBuilder 3 роки тому +4

      Yup, now off to add this to every clamp() I've written.

    • @bulkywallnut5674
      @bulkywallnut5674 3 роки тому +2

      Can someone further explain this? I don’t understand. Thanks

    • @technikhil314
      @technikhil314 3 роки тому

      @@bulkywallnut5674 as you zoom in your viewport shrinks hence actual vale of vh and vw also goes down but rem stays same regardless of viewport size.

    • @badunius_code
      @badunius_code 2 роки тому +2

      Never considered pinch zoom 🤔
      Otoh, why would you want to pinch zoom if font size is appropriate?

  • @SolomonOni-d1y
    @SolomonOni-d1y 29 днів тому +1

    You have made me I love with CSS and I'm really surprised with the amazing things you can use only CSS to do

  • @munaq-jp
    @munaq-jp 3 роки тому +10

    I've been using clamp instead of media queries for a while now. But using both with variables is brilliant. I absolutely love it.

  • @fahimsangharriyat495
    @fahimsangharriyat495 3 роки тому +3

    clamp(3.5rem, 12vw + 1rem, 12rem) which is amazing. Now I will be use in my all projects

  • @SachinShukla
    @SachinShukla 3 роки тому +15

    “frontend friends.” for months i thought he was saying “friend and friends.”

    • @iamkeir
      @iamkeir 7 місяців тому

      Mind = blown 😮

  • @sumitwadhwa8823
    @sumitwadhwa8823 3 роки тому +35

    As always, great stuff. I think min, max, and clamp are pretty awesome.

  • @gregoryolenovich6440
    @gregoryolenovich6440 3 роки тому +5

    Damn your responsive layout tutorials are so helpful and I'm a fairly experienced dev. I love the clamp thing. I have been using min to get something similar but I like clamp even more.

  • @Atractiondj
    @Atractiondj 3 роки тому

    it's nice to see a video with material about which you knew for 6 months already

  • @brunovincent1969
    @brunovincent1969 3 роки тому

    Man , that's absolute genius, been fighting with this for years! I'm saving this video with my legacy firefox youtube downloader, that vid going in my library!

  • @henkmeerhof8647
    @henkmeerhof8647 11 місяців тому

    Great that you explain we should not base font size on the view port size. It is not how typography works. Typography works on view distance (and you eye sight) so unless our devices get a sensor to measure how far our eyes are away from the screen we are reading, we have to work by the experience we have. Here we are in luck as we already use type for centuries, so we have some experience. An experience that is supported by some science of the last century where reading over distance became a real thing, like how large should type be on a road sign...
    The other great thing I would implement as soon as possible is to gather as much typographic parameters and behavior in one place, somewhere at the beginning of (css) files.

  • @Cowglow
    @Cowglow 3 роки тому +1

    The Clamp trick is amazing!!
    Thank you for the tips!

  • @gonzaotc
    @gonzaotc 3 роки тому

    Kevin, you are the fucking best, you know, right?. This week I learned A LOT from you. Your content is incredible. Everything I have to do and find out how to on my projects, I search and you explained it better than anyone.

    • @gonzaotc
      @gonzaotc 3 роки тому

      Also finishing your CRL 21 days course

    • @KevinPowell
      @KevinPowell  3 роки тому +1

      Thanks so much! So happy that you're enjoying me content 😊

  • @petarkolev6928
    @petarkolev6928 3 роки тому +1

    Kevin, you are my savior! Yet another amazing video ❤️Thank you so so much and I wish you an amazing new year!

  • @MeetDaveG
    @MeetDaveG 11 місяців тому

    Thanks for this video Kevin. Just used (clamp) for one of my designs after this. Super helpful.

  • @CarlosAlgms
    @CarlosAlgms 3 роки тому

    I've never heard about clamp, I loved it, thanks for the video.

  • @cintron3d
    @cintron3d 3 роки тому

    Thanks!

  • @BasilBear
    @BasilBear 2 роки тому

    Thank you, Kevin, that was precisely what I was looking for. I have subscribed for more. :)

  • @RougeEric
    @RougeEric 3 роки тому

    Interesting!
    I tend to use em (not rem) in all instances while making sure to always keep things very simple:
    End-points (so , , tags and the like) get an EM value, all padding, margins, etc. use em values, image sizes use em values (with srcset so the image can be much larger but display properly based on the actual display needs) or vector art.
    Then I will have "containers" like a or , or even a which can be designed to "mod" the size (say you want "big quotes", then that tag gets a font-size of 1.4em for example). Anything drastic or that could have many exceptions will be set using a class instead of a tag so that I don't have to override these em values constantly.
    Then I just use my body's font-size as a responsive breaking point. That clamp trick would work wonders there, since it would affect the entire site's content within controllable bounds!

    • @user-yz5hj3zg2x
      @user-yz5hj3zg2x 2 роки тому

      I don't know if you already watched this, but if not, take a look: ua-cam.com/video/pautqDqa54I/v-deo.html

  • @rconr007
    @rconr007 3 роки тому

    Awesome as always. You never disappoint!!!

  • @chanel310the7
    @chanel310the7 3 роки тому +1

    I am so happy I found this channel 😭

  • @ericnjanga3245
    @ericnjanga3245 Рік тому

    I love your approach. Great job.

  • @vasiovasio
    @vasiovasio 2 роки тому +1

    Objective and Useful video! Thank you!

  • @unizfrhn2803
    @unizfrhn2803 3 роки тому

    Man, why is this guy so awesome with CSS.

  • @zachjensz
    @zachjensz 3 роки тому +12

    People really gotta clamp down on text like this :D

  • @bobbysilver272
    @bobbysilver272 3 роки тому

    Yet another great video Kevin! Thank you.

  • @zrowork1362
    @zrowork1362 3 роки тому +1

    Great, helpful staff. Love how you explain what I shouldn't use. Made my day. Thank you!!

  • @ucielsola
    @ucielsola 3 роки тому

    As always, outstanding. Thanks, Kev!

  • @fran_sar
    @fran_sar 3 роки тому

    Wooooow, you rock!!!
    Your videos are awesome, clear and to the point.

  • @crawfordpaul7890
    @crawfordpaul7890 2 роки тому

    Really good stuff. I'm learning a ton from your videos. Thanks for putting them together.

  • @ViorelMocanu
    @ViorelMocanu 3 роки тому

    Excellent technique with the clamp + calc (implied)! :) Thanks!

  • @hassanfayed1427
    @hassanfayed1427 4 місяці тому

    This is so helpful. Thank you so much!

  • @lakshyachopra_
    @lakshyachopra_ 3 роки тому +1

    Amazing stuff as always, thanks a lot!

  • @anuragsuryawanshi4177
    @anuragsuryawanshi4177 2 роки тому +1

    He has video for my every css doubt

  • @aggelos_kilitis5405
    @aggelos_kilitis5405 3 роки тому

    Amazing work man, you have taught me a lot of things from your videos! Keep it up!!

  • @517design
    @517design 3 місяці тому

    good point about VW and accessibility issues.

  • @norvusordoseclorum
    @norvusordoseclorum 2 роки тому

    I think the fall in love with CSS bit has drastically changed!

  • @blacknoire
    @blacknoire 3 роки тому

    Defo my favourite UA-cam coder ♥️

  • @MrSteini124
    @MrSteini124 3 роки тому

    This is fantastic, thanks so much for these fun vids

  • @asrockriel
    @asrockriel 3 роки тому

    Great Video, Right now, was currently using vw, vh approach never heard of that clamp function seems really interesting, the only issue i see is the support. It's actually less supported than grid-layout, but surelly when browsers keep evolving will be a must use.

  • @schism1986
    @schism1986 3 роки тому

    Neat! I've tried to do this with .less and never was able to, this is really nice!!

  • @RaveKev
    @RaveKev 3 роки тому

    Danke!

    • @KevinPowell
      @KevinPowell  3 роки тому

      Thanks so much!

    • @RaveKev
      @RaveKev 3 роки тому

      @@KevinPowell We have to thank YOU! I realy love your style, the length of your videos and your content.

  • @nitram_nosnibor
    @nitram_nosnibor 3 роки тому

    What a great solution!!! I really enjoyed this vid (whilst eating breakfast ha ha). Thanks Kevin 👍🏻

  • @pwos36
    @pwos36 3 роки тому

    謝謝!

  • @LemonBoy_483
    @LemonBoy_483 Рік тому +1

    thank you for help me : )

  • @kevinfredericks2335
    @kevinfredericks2335 3 роки тому

    Clamp creates an s-curve for mapping font size to screen size. You can also achieve this with calc(#vw -#vw) but setting bounds with clamp() is much more Design Driven. Anything that helps detangle the mental exhaustion of mapping design goals to math is a big win

  • @amankaushik5833
    @amankaushik5833 3 роки тому +1

    awesome, exactly what I neeeded

  • @photoinshot1355
    @photoinshot1355 Рік тому

    Great tutorial very helpful and demonstrates responsive text methods very well, thanks. I am not very experienced with css so this is a great introduction to responsive text. I am very interested to learn more about the overall layout design with this newspaper - magazine type layout which is great and makes the whole page more interesting to look at and more inviting to read. Do you have another video explaining the concepts behind this layout design? I can work out quite a lot from the code you kindly supplied in the codepen (thanks!) but some of the code I don’t understand. Thanks again!

  • @wwhill8033
    @wwhill8033 3 роки тому

    Great video, thanks Kevin

  • @AniketEdot
    @AniketEdot 9 місяців тому

    Thank you for this video. Really helpful.

  • @kelvindogbe635
    @kelvindogbe635 3 роки тому

    this video is awesome thanks a lot Kevin

  • @TomasHradckyComposer
    @TomasHradckyComposer 3 роки тому

    Wonderful.
    Understandable.
    Incredibly useful.
    Thank you.

  • @SivakD
    @SivakD 3 роки тому +2

    Clamp is a good one. Thanks. I kinda wish they had something where you could set a size based on the parent container's width instead of the whole viewport.

    • @roberotful
      @roberotful 3 роки тому +1

      percent!

    • @Danko_HS
      @Danko_HS 3 роки тому +1

      @@roberotful I 100% agree with what Rob said 😉 Or is it 80%? I don't know anymore.

    • @ormuriauga
      @ormuriauga Рік тому

      Doesn't work for font-sizes though :(@@roberotful

    • @roberotful
      @roberotful Рік тому

      @@ormuriauga I think setting font-size as percentage goes by percentage of the element-level font size, similar to em (I could be totally wrong, just my present understanding). I think percentage is a bit unintuitive for font sizes though, I usually use rem!

  • @DarkAsylumVideos
    @DarkAsylumVideos 3 роки тому

    This is something I've been trying to figure out how to do via SCSS. Any chance you make a follow up with how to do this?
    Keep up the great work.

  • @AI_Bibliophile
    @AI_Bibliophile 3 роки тому

    Wow This is Great Man ❤️

  • @shapelessed
    @shapelessed 3 роки тому

    Ok, honestly I rarely ever say that but today I actually learned something I didn't know about..,

  • @AFE-GmdG
    @AFE-GmdG 3 роки тому

    CSS Variables - a great invention!

  • @roberotful
    @roberotful 3 роки тому +4

    I've been sacrificing accessibility a bit on some of my projects by using viewport measurements, love the clamp idea. To solve the problem of vw getting super big/super small I had swapped to vh which I actually find to be a pretty good scalable solution - works well on both desktop and mobile once you find the sweet spot - if you don't mind it always being the same size regardless of zoom (which I think you obviously should mind now that I know clamp exists!)

  • @ryandornanuk
    @ryandornanuk 8 місяців тому

    Amazing video, thank you so much.

  • @FawadJaved
    @FawadJaved 3 роки тому +1

    whats with 499 and 599 and 699. almost every time you have you remove 99 to replace it with 00?

  • @smartdub
    @smartdub 3 роки тому

    Wow, that ‘clamp()’ 🤯 i didn’t know about it. Merci

  • @ericdimarzio5756
    @ericdimarzio5756 Рік тому

    Wow this is great! Thank you thank you thank you!!

  • @matteozhang7140
    @matteozhang7140 3 роки тому

    Literally saved my day!!

  • @anatanhofer3191
    @anatanhofer3191 3 роки тому +1

    Great content as always! :) I really appreciate that you talk about pros and cons for every decision. I have only one question, if I read correctly clamps() is not supported by Internet Explorer... so how the page behaves when you open it in IE? I am not sure how many people still uses the IE but I think it is still in use in business segment.

  • @andreibade
    @andreibade Рік тому

    8:08
    Why add 12vw + 1rem, when you zoom it won't scale right
    Why don't you multiple 1rem by some vw instead so it will scale better when zooming?

  • @kaanozk
    @kaanozk 4 місяці тому

    the answer i was searching for.

  • @TK-lv9sc
    @TK-lv9sc 3 роки тому +2

    I have another method that works quite well for me.
    First, on root, I add a base font size with viewport width units, and then media queries that change that base font size. For example, for large screens "font-size: 1vw", but for smartphones "font-size: 3.5vw".
    Then I set everything using clamp usually, just to make sure that everything is in line and doesn't get oversized. Example "font-size: clamp(16px, 1rem, 22px);"
    It works great for me, and everything scales almost fluidly when resizing the window. I also use this root font size for margins and padding as well in some cases.

    • @jabeztadesse
      @jabeztadesse Рік тому

      What clamp generator tool do you use?

  • @Bluukeson
    @Bluukeson 3 роки тому

    I have been using a root vw font-size that is based to the Adobe XD artboard size.
    I'm using scss functions to aid me with this but it can be done with calc.
    this would look something like this:
    html{font-size: calc(20 / 1280 * 100vw)}.
    This will make it so that 1rem is 20px at a viewport width of 1280px.
    As you resize the viewport this relation will stay the same.
    Then you can use a different relation for a mobile width using media queries.
    This allows not just my text but other elements with rem/em values to scale perfectly with the viewport width.
    As a nice bonus I can use the same px values used on the XD artboard. I just have to convert them to em/rem.
    I use scss functions for this again to keep things neat but you can use calc for this as well.
    With a container width of 500px it would look like this:
    width: calc(500 / 20 * 1em);
    20 being the base font-size that is also defined in the root font-size.
    This certainly brings a lot of advantages. My designer has a print background
    so a lot of his layouts heavily rely on the right ratio between text and other
    elements like images.
    But of course there a downsites as well. Aside from running into some unexpected
    bugs from time to time the two major issues are:
    1. zoom accessibility
    2. some layouts don't work very nice on larger screen sizes because you end up with very
    litte content being visible at a time.
    this might all be a bit much for a youtub comment but oh well xD

  • @luciterriee
    @luciterriee 3 роки тому

    Woah, clamp() is native CSS? Awesome!

    • @RickBeacham
      @RickBeacham 3 роки тому

      I think scss is moving to native css.

  • @eminm6383
    @eminm6383 3 роки тому

    awesome job dude, thanks.

  • @aleksandercross5936
    @aleksandercross5936 2 роки тому

    Really good stuff., thank You!

  • @RehctubNomis
    @RehctubNomis 3 роки тому

    LOVE that t-shirt!

  • @chrisstucker1813
    @chrisstucker1813 Рік тому

    Killer tutorial !

  • @bobrobertsNotUrBob
    @bobrobertsNotUrBob 3 роки тому

    damn that is smart, never thought about root on media queries

  • @metekavruk_Alanya
    @metekavruk_Alanya 3 роки тому

    Loved the t-shirt... and tutorial of course...

  • @КостянтинПетля
    @КостянтинПетля 3 роки тому +2

    I have watched a few of your videos. Good work! But I have a question about your approach to the rem. For example, we can see 14px as a base font size in our mockups. There are several approaches: 1) to use 62.5% for HTML font size and 1.4rem for body, etc. 2) to use 100% for HTML and 0.875rem for body, etc. 3) to use 87.5% for HTML and 1rem for body, etc. 4) others? Wiche one do you prefer and why? The Bootstrap 4 sets $font-size-base: 1rem to the body and nothing to HTML. The Foundation sets $global-font-size: 100% to HTML and nothing to the body. Both of them think in the base font size categories (1rem). I had experience with fluid typography by changing the HTML font size with a formula with vw (14px on mobile to 18px on desktop). It works well until we don't have mockups for several screen sizes. You can't use fluid rem in Foundation if the gutter is the same on mobile/tablet/desktop mockups. Long story short: I'm looking for the best approach with rem/rem-calc()/sizes/typography.

    • @pahtashow
      @pahtashow 2 роки тому

      ответ нашли на свой вопрос ?

    • @permanar_
      @permanar_ 2 роки тому

      Never change your fontsize to 62.5%. That's not a very wise choice.

    • @theeemed
      @theeemed 2 роки тому

      @@permanar_ why shouldn’t you do that?,

  • @UndefinedComment
    @UndefinedComment 3 роки тому

    Something that I don't really understand is:
    Do I have to adjust the font-size for every element?
    Because if I change the font-size of , every rem unit will adjust as well, which I don't want.
    It seems, as if I should define all font-sizes via classes, which I think is unnecessary for all regular text. I just want to overwrite the font-sizes at each breakpoint, like I do with h1-h6 and so on.

  • @thedeveloper9896
    @thedeveloper9896 3 роки тому +1

    there should be a one css line for responsiveness that will remove the stress of most people (but i know its very hard for one line for responsiveness automatically)

    • @KevinPowell
      @KevinPowell  3 роки тому +3

      yeah, too many variables and things at play. Plus what fun would that be? 😅

  • @carolmckay5152
    @carolmckay5152 3 роки тому

    This is a great approach thanks Kevin, the vars, I have been struggling to get my clamps just so with this last project I am working on and am thinking I will drop it for the custom variables approach for future projects and give the IE browser a fallback. One thing I'd like to add, the mobile body text needs to be 1.3 times bigger than desktop because people tend to hold the mobile screen further from their face.

  • @benja-min1588
    @benja-min1588 3 роки тому

    Thank you Kevin!

  • @kiwicrafter
    @kiwicrafter 3 роки тому

    That is great when you have only one css file, but I use quite a few css files, one for images one for navigation etc, all my media queries are in one css file, easy to find what you are looking for indeed.
    EDIT: all my roots are also within one css file.

  • @philwatts
    @philwatts 3 роки тому +1

    What's a "headach"?

  • @mathzygote
    @mathzygote 3 роки тому +1

    Thats awesome🔥🤯

  • @papluha32
    @papluha32 2 роки тому

    Great! ♥♥♥ :-) Thank you Kevin. Really helpful.

  • @floraposteschild4184
    @floraposteschild4184 3 роки тому +1

    Those two :roots...yet another "oh, that's smart" moment in your videos. Thanks!
    If I understand correctly, that 1rem of the 12vw + 1rem is just a token amount, so you can pinch the screen -- is that right? If so, is there any reason NOT to put similar measurements throughout your CSS? e.g. for the --fs-400, could you put .5vw + .5rem, or whatever the size equivalent would be?

  • @cortarelva
    @cortarelva 3 роки тому

    Pure gold right here.

  • @MuhamedAlfaifi
    @MuhamedAlfaifi 3 роки тому

    I like your css content

  • @ChazAllenUK
    @ChazAllenUK 3 роки тому

    Seems like your clamp scaling will behave differently depending on the zoom level. The lower & upper limits grow faster than the target (because zoom only affects rem not vw), so I would expect >100% zoom to min-out/max-out at a proportionally wider screens, and

  • @msk7148
    @msk7148 3 роки тому

    All fonts - make in Rem < and @media maybe change just a ----- Rem?

  • @kinstar
    @kinstar Рік тому

    What do you think about using an alphabet like the phonetic alphabet
    --fs-alpha: 10rem;
    --fs-bravo: 5rem;
    --fs-charlie: 4rem;
    --fs-delta: 3.5rem;
    do you think this is silly 😅

  • @marwanak10
    @marwanak10 Рік тому

    I use clamps but let's say the max size is 32px, then when viewing on a 4k large monitor the font is small again and we go back to the media query solution...

  • @jabeztadesse
    @jabeztadesse 3 місяці тому

    Why do you always use hsl for colors? Is it a pereference thing?

  • @RickBeacham
    @RickBeacham 3 роки тому

    Thanks for the pro tips.

  • @MackaBaer
    @MackaBaer 3 роки тому

    pure gold

  • @huseynaliyev3457
    @huseynaliyev3457 3 роки тому

    Great solution. And by the way you have exactly 350.000 followers by now.

  • @kelvindogbe635
    @kelvindogbe635 3 роки тому +1

    Kev. can you please do a tutorial on css design system/layout/structure. I will really be looking forward to that. thanks

  • @AbdicateDotNet
    @AbdicateDotNet 3 роки тому

    Awesomeness for sure! Q: Why would you not want to do the clamping for all the font settings?

    • @KevinPowell
      @KevinPowell  3 роки тому

      There are ways to do it, but I find it's already finicky enough. Maybe I'll change my mind one day, but I find this balance works well for me :)

    • @DarKcS2
      @DarKcS2 3 роки тому

      @@KevinPowell Is the lack of IE and other niche browser support of clamp() enough reason to be wary of using it?

    • @jcota2003
      @jcota2003 3 роки тому

      @@DarKcS2 IE11 was the last IE version and isn't even receiving security patches any longer... non-chomium edge on the other hand is the new problem child... other than people that insist on their custom browser flavor of some weird webkit clone.

  • @chhavimanichoubey9437
    @chhavimanichoubey9437 3 роки тому

    scss and custom properties are like gems in a gemstone collection of css properties.

  • @DaveEricsson
    @DaveEricsson 2 роки тому

    I built a logo name slogan hero in svg and to approve the relations always stay the same gave the svg a relative unit. Works fine for all screen sizes and is super fluid, but is definately no work case for paragraphs 😄

  • @НикитаС-ь3ь
    @НикитаС-ь3ь Рік тому

    What about line-heigth? Can we use clamp() with it?