Stop fighting with CSS positioning

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

КОМЕНТАРІ •

  • @adamuk73
    @adamuk73 2 роки тому +176

    Positioning has always been a sticky subject matter, relative to other CSS topics. This video has fixed so many issues I had. Absolute outstanding video KP.

  • @zachjensz
    @zachjensz 2 роки тому +57

    This puts me in a better *position* with my styling, thanks Kevin!

    • @KevinPowell
      @KevinPowell  2 роки тому +13

      🥁

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

      Hehehe he said it he said it

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

      @@KevinPowell badum tisshh

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

      I think the "funniness" of that joke is *relative* to the reader 🤔 xD

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

    Always so thorough with your explanations. I already used "position : relative" on the "parent" of an element with "position : absolute". But I didn't know why I was doing that, it just worked. Now it all makes sense. Thank you

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

    Wow. I usually don’t comment, but this video deserves all the likes and all the comments in the world. Nobody explains these concept in the usual tutorials and this information is also hard to google. Great job, Kevin!

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

    You're the best! 8:51This is EXACTLY what I was doing. I had an idea of containing blocks, but I wasn't sure. Now I know it IS containing blocks. Thanks so much for this video!

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

    Well explained. One thing regarding position fixed. All of those properties you've mentioned (perspective, backdrop-filter, etc.) are not a creating a "weird edge cases" :). Those properties, including position fixed, cause the browser to create a new composite layer. Element with position fixed is actually 'limited' to its parent layer, not the viewport nor its parent "element". If parent element creates a new composite layer, then position fixed element is inside that layer and is limited to it, otherwise it is fixed in the main, document layer. There is a layers panel in dev tools (ctrl/cmd + shift + p -> "layers") where you can view the layers and see why they got created.

  • @N.A.Schilder
    @N.A.Schilder 2 роки тому +1

    I’m a student who wants to be a front-end developer and I’m so greatful for your videos, thank you so much. You make it all so interesting and so much easier to understand.

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

    At 04:50 I finally understood position: absolute to position: relative. Whew, thanks so much King :)

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

    I was just working on this exact problem. I choose to believe Kevin is making videos for me specifically.

  • @xil8008
    @xil8008 5 місяців тому

    My guy actually saved my webdev assignment, thx a lot

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

    Interesting! These examples are indeed issues I run into , quite a lot. That together with z-index / stacking-contexts is a big reason I put some designs in the fridge. One of those design is multiple section dividers with clip paths and fixed backgrounds go under it once you scroll over, never got around into let it work properly.

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

    I like the picture in picture edits to accommodate your 2 screens, works great👌

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

    Thank you. Every time I watch your videos I learn something completely new. Even if I thought I knew everything about some part of CSS.

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

    omg Kevin, no words to describe you, and how much am learning from your channel, thank you thank you thank you

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

    the position fixed tip was amazing. sometimes i really did not understand why it was not working and i was like what is going on. thank youu, Kevin!!

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

    All the concept about the container block open my mind , thanks

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

    *So many* things create a new containing block, from any sort of transform to masking or filters (including backdrop-filter). It's kind of rare to get into issues with it, but when it happens, in can be really infuriating and hard to debug if you don't know how containing blocks work

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

    Juste amazing content here. Exactly what I needed

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

    Great video! I still remember the frustration of the first time I crashed into the fixed position issue. I was working on a project where the design commanded the use a hamburger menu toggling a full-screen overlay on mobile, with the catch that the last item on the list was a highlighted button for the main CTA, and said button would be the only from the list that remain visible for wider viewports, fixed to the top right. Tried switching the button from its static position to a fixed one on wider viewports, but the transforms that toggled the overlay created a containing block, and the button end up nowhere to be seen xD

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

    So that explains it, containing blocks... Thanks, Kevin. This fixed an issue I was having today.

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

    Kevin, that was an amazing Video. Thank you very much for making such a great piece of content. Your truly make the world a better place.

  • @crim-son
    @crim-son 2 роки тому

    I always learn new things with Kevin, no matter how good I am with CSS, thanks Kevin ❤️🌹

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

    I'm new to front end and your videos really help. Thank you 💗

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

    Such an informative video, Kevin. Thank you! This is one of your best! ❤️

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

    Super high quality content Kevin. Thank you, best teacher ever

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

    its like this dude reads my mind. I was having trouble with this few days ago

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

    18:45
    just yesterday I've used "backdrop-filter" and its broke everything, so I switched to do blur with ::before.
    Now, I guess, I understand what was the reason for that behavior xd

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

    Amazing kevin thanks alot for sharing the important concepts for free.

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

    For some reason I've always had it in my head that positions were all relative by default. This may explain a lot of my confusion over the years.

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

    Thank you. Am going to watch this a few times.

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

    Danke!

  • @user-ms13w
    @user-ms13w 2 роки тому +1

    Kevin thank,
    all times , the best learn's

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

    0:19 How did you know that position sticky has never ever worked on my projects and I have been painstakingly using JavaScript the whole time?

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

    the title explains my relationship with css pretty well

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

    Awesome tutorial as always. thank for it KP.
    Kevin, could you please create a tutorial about how to make a multilabel responsive mobile first drop down navigation menu & then hover effect on laptop/desktop version? All of the tutorials in this topic on YT are desktop first approach.

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

    Hi, Kevin. Thanks for another great video. Is there a reason you did not use and aside for the sidebar?😁

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

      Just putting together a fast example 😅

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

    collapsing margins are a huge annoy
    i usually disable margins for everything and never use margins anywhere
    we already have `gap` now and we can just add padding to parent
    so margins are not needed much anymore
    unless you are rendering a document like md file and stuff, what html designed for in the first place way way before
    but now, margins are not needed by default for anything, it just creates confusion most of the time
    if im gonna render something like an md file or an article and stuff i would just put it inside a shadow dom anyway with an embed component and it would just work as expected

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

    15:42 "You also have the social sharing things that suck" 😂👌🏻✅

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

    Super helpful, thank you!

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

    Hi, can you please do a video on the advantages of using BEM vs something like '.content .sub-component' etc? Seems to me you can just define what the role of each block is, and then target as appropriate via selectors?

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

      I'm a total newbie at CSS but I have tons of experience writing code for myself but also debugging code that others have written.
      To me, the advantage of BEM would be: A) if I'm writing code, it will be easier to remember what I called the class so I would not be constantly having to look up "what exactly did I call that thing?" B) if I'm looking at someone else's code, I would quickly figure out the strategy and then be able to mostly guess what a class is meant to do just based upon the name rather than having to go look it up constantly.
      Generally, you want the "words" (the parts that make up a particular name in this case) of your "language" to be as minimal as possible so you can learn the entire language more easily. You want the "syntax" (the structure of you names) to be simple, logical, and concise so, again, it is easy to learn. Consistency is also going to play a major part in unburdening the mental load of "speaking" the language.

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

      Its mostly for as projects scale and keeping everything at the same specificity level.
      The issue often isn't that people don't understand the impacts of raising specificity with descendant selectors, but when you have a team of people doing stuff, sometimes things get a little messier, and maybe someone makes a .title that messes with some .component .title that wasn't really intended to, so by having .component__title, you know the styles are more isolated. It's more of a "if we do it this way, there is less chances of running into some stupid problem that's annoying to fix" than anything.
      It's also just one approach, I personally think having some level of "nesting" with descendant selectors is fine, and can even help enforce proper markup.

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

    A small question, just wonder how to put a close-quote directly after the content of a paragraph using a pseude-element ?

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

    You are a great tutor ❤

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

    I avoid setting fixed widths and heights wherever I can. I really generally only use bits of padding here and there combined with either flexbox or grid plus some gap, depending on how insane the design is. If the content gets squished a bit width-wise, so be it. It's more natural for a web page to flow vertically/downwards anyway.

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

      I sometimes use max-width, min-width, and min-height. Such as max-width: 72em; min-width: 9em; min-height: 3em;
      If I'm feeling fancy, I can use a clamp() or something

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

    Hi Kevin, and thank u for the video. I'm struggling with some position:relative/absolute creating a little map with some dots inside.
    The map has position relative and the 3 dots, has position absolute and some value in top and left for locate them in the correct city. In this type of work how can i achive the best responsivness?

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

    A good exercise is to position a container at various positions on the viewport.
    Top left, top right, bottom left, bottom right and centre.
    But not cheating with margins or anything like that.
    Then add another container and try to position two containers.
    Then three, and so on.

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

    i agree, you truly know how to TEACH! asante

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

    Not sure if it gets the "closing the quote job" done the same way, however instead of `content: close-quote` with a `font-size: 0rem` perhaps `content: no-close-quote` is more "elegant"? :two-cents:

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

    Why is the up arrow in the scroll to top button inside of its own span?

  • @666Bockwurst666
    @666Bockwurst666 2 роки тому

    perfect timing :)

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

    Hey Kevin, great video!
    At work we‘re only using scss by now, and I was just wondering why you aren’t? Do you have any specific reasons for that, because I think it’s just handier in every way.
    Thanks in advance!

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

    I want to stick footer at bottom of page.
    Case1: if content on page is less footer shift upword in viewport. I want to stick footer always stick at bottom even thought page length is less.

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

      Bit different than what I looked at here, but I do have a video on that! ua-cam.com/video/yc2olxLgKLk/v-deo.html

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

    So position context for an absolute positionated element reletive to lets say , its relative positionatted parent is function of parent padding and element margins? Thank you!

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

    Hey Kevin, tthink you could do videos on a Figma alternative Lunacy? I have been wanting to use it, but I prefer video tutorials. I hope you will do a video on it.

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

    Great video Kevin! I’ve shared this with many of my colleagues.
    I’ve experienced setting a CSS transform on a parent element causes a ‘position:fixed’ element within to start listening to the container context of that parent instead of the viewport. Is there any other way around this? - other than moving the element to a different part of the DOM?

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

    The goat doing goat stuff 💪

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

    Very timely

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

    Thanks Kev! You make everything simple. Can you try making videos about solving my other life problems too?😅

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

    Position sticky to me is the single hardest thing to use on complex sites in my opinion. It's so frustrating that I even use Javascript instead.

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

    Interesting, I didn't know about that strange behavior of fixed

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

    CSS needs a "I really want that block to go here!" attribute.

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

    11:35 hahaha now *that* kind of hack reminds me of old school CSS. Better leave a comment in that code, 'cause surely coworkers will have no idea why it's there

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

    I had started to positioning with other relative, absolute,fixed

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

    If I want to learn something new every day I just watch your videos. Your range of knowledge is amazing. It's crazy how you can make CSS exciting. Well done man!!!
    !! IF YOU HAVEN'T SUBSCRIBED YET. SUBSCRIBE NOW. The work Kevin puts into these videos is a lot of work. I am sure he enjoys making them, but it's still a lot of work. Not to mention he does it with us in mind. So subscribe for him. Doesn't cost anything so what will it hurt. Nothing.

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

    I like the video. I hope my questions don't imply that I didn't...
    So, position: fixed looks at the view port EXCEPT for case A, B, C, ... Fine. But:
    A) Is there a reference to the complete list of exceptions?
    B) Do you know the "logic" of why these exceptions were created? If it is looking at the parent element with on of these special cases, how can that be leveraged to do something that others could not be done?
    Your course sounds like what I need. I'm going to check it out. CSS frustrates the @#$%!!!!!!! out of me. This helped although I've been listening to a lot of your other videos and some of these things have already been covered.
    OH!!! One point. The way that you diagnosed the problem with position: sticky is super helpful. That is the type of things I need. Teach me how to fish (i.e. how to debug and efficiently find solutions on my own)... don't just give me fishes (answers to specific problems).

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

      The why for the position fixed thing is, from what I understand, a side effect of being able to get those things to work as they create new layout contexts, which the browser needs to be able to do for those effects. There is a list on the MDN page. As for leveraging it to do something useful... I can't think of anything as hard as I've tried, lol

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

    What is an ancestor on CSS, also what is a father?

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

    To join the puns train... Now this is a lesson that's gonna stick to my brain, and put me in a good position relative to my work. This video was an absolute pleasure to watch. Thank you.

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

    is there a way to specifically set a containing block from a children?

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

    CSS is easy. Then you watch Kevin Powell. Then you see how easy CSS is and shouldn't be ignored (in the name of "not real programming").

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

    The fact you didn't highlight the entire H3 and then just left it like that for ages set off my OCD.

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

    Today I learned positioning tips but also.... you can just write "content: open-quote" in your CSS for special quotes instead of using an SVG????

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

    Also will-transform break fixed.

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

    I want you to be my mentor, Kevin😁

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

    plz do provide source code it really help the beginer

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

    Putting position absolute on inline elements behaves different
    Like checkbox

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

      Once something is position: absolute, the display property sort of goes out the window, and it's pulled out of the flow anyway... I can't really think of a huge impact that it would have though, care to elaborate?

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

      @@KevinPowell
      When I was trying to create a custom checkbox
      Using opacity 0 to make it not visible but still on the page
      And together with position absolute, the checkbox no longer takes space.
      Even when position relative is not declared on its parent or any containing block. The checkbox is still within its original containing block if you increase the opacity a little to see it.
      I think position absolute behaves different for input elements or inline elements in general.

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

      @@emmanuelxs6143 Would be nice to have an example of that.

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

      @@Laura69 yeah

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

    Audio was a little echo-y this video

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

    Wouldnt this be much easier with using flex (display flex)

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

    what's the point of still using base css when tailwindcss is undoubtedly more performant?

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

      1. To use Tailwind CSS, you need to understand CSS.
      2. Not everyone likes it.
      3. Tailwind CSS cannot be more performant than CSS because Tailwind CSS IS JUST CSS!!! Perhaps you meant JIT compilation and class reusability.

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

      Yeah this is like saying “why do I need to read and write when I have words”

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

      And as for performance, yeah Tailwind isn’t more performant, it’s just CSS. If you’re talking about a large scale production application… maybe? But I’m still not convinced that there are any data savings by taking clutter out of the style sheet and shoving them into the markup.

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

      Is it though? They're just using purgeCS, which anyone can use. As for repeated CSS, once things are gzipped, you probably won't really see a difference anyway, and any decent host is going to gzip automatically.
      My website, while simple enough, is only shipping 4kb of CSS to the user. Even if using Tailwind would cut that by 50% (which I doubt it would), that's 2kb of savings. I could think of *a lot* of other things that would give me a bigger benefit.
      Let's bring things up to a bigger site, and say I have a 100kb CSS file (that's what tailwindui.com has), gzipped it's down to 18kb, which is what the user downloads. Even if I recreated their site without using Tailwind and had a 200kb or 300kb file, I'd only be shipping about 30-40kb to the user, and probably less than that since gzipping tends to have bigger effects on larger files (since there is more repeated code, which is what gzip is amazing at compressing). If you're worried about 10-20kb optimizations on a CSS file, you're down to the real nitty-gritty and probably wasting your time.
      I'm not saying this to poop on Tailwind. I get why people like it, and that's fine. I just don't like hearing about how it can help with performance, because I think there is a lot of disinformation out there on that topic.

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

      And can someone please correct me if I’m wrong: I’ve observed tailwind doing some client side script processing to make the class names do some funky stuff they normally wouldn’t be able to do. If true, tailwind is certainly slower than CSS because it’s doing some JavaScript execution which CSS obviously does not

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

    16:12

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

    🤣«that social sharing thing that sucks!» 👍

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

    What about when the parent has an overflow:hidden when using position sticky?