Learn how to implement scroll animations with HTML, CSS, and JavaScript. Use the JS IntersectionObserver and CSS transitions to implement a native "animate on scroll" effect that works in any browser.
КОМЕНТАРІ: 1 100
@ruriko1237Рік тому
I see Jeff teaching us how to center a div -> I download the video. This might be the best tutorial of all time.
@alfredogonzalez9420Рік тому
what can I say, I'm a SIMPle man.
@totoshampoinРік тому
I mean, he did that already ukposts.infonjdJeu95p6s
@MicLiegРік тому
ukposts.info/have/v-deo/ppqVfpuscGuhl6c.html Thank me later
@reesericdotciРік тому
CSS tricks complete guide to centering is amazong
@gauravrajghimire6396Рік тому
Teaching developers how to center divs... Should be the default background video on stack overflow...
@devqubsРік тому
every coding tutorial should be like this, clear, concise and no BS.
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@user-cl9qv7hj9xРік тому
and no Brawl Starts. Absolutely agree
@psychomonk2443Рік тому
If you want tutorials without bs, pay the creators that do so
@kingfatpig3512Рік тому
What does BS stands for?
@user-cl9qv7hj9xРік тому
@@kingfatpig3512 bullsh!t
@figmentfireРік тому
It's sooo nice to see some vanilla HTML, CSS and JavaScript in use!
@jaimevelasco7957Рік тому
yes, i was just going to write that
@brandonfox9618Рік тому
Plain vanilla is my favorite ice cream flavor!
@kingfatpig3512Рік тому
what is vanilla ?
@figmentfireРік тому
@@kingfatpig3512 plain, no frameworks, no libraries, just plain "vanilla" flavour code.
@kingfatpig3512Рік тому
@@figmentfire ok thanks
@chrismdev_8 місяців тому
I love how you talk about the reasons behind your decisions. Most tutorials leave out the why, making it way more difficult to understand.
@donniedamatoРік тому
Two things: You can add the following one-liner to toggle a class when the entry is intersecting. entry.target.classList.toggle('show', entry.isIntersecting); Instead of turning off the animation with prefers-reduced-motion, turn it on. @media (prefers-reduced-motion: no-preference) { .hidden { transition: all 1s; } }
@pepkin88Рік тому
Disabling for prefers-reduces-motion is easier to do. Firstly, all the code describing the animation details is with the rest of the styling. Secondly, it's easy to remove all transition on the page with a single selector: *, *::before, *::after { transition: none !important; }
@beyondfireshipРік тому
Great improvements
@invinciblemodeРік тому
@@pepkin88 nah, it goes with the mobile-first principles or in this case animation-less-first principle, where you assume everyone does not want animation unless stated otherwise. It’s a better way to handle prefers-reduced-motion
@DavidMulderOneРік тому
@@pepkin88 General reminder: Reduced motion is *not* no motion! Browsers could trivially turn off *all* motion in that way. The point of prefers reduced motion is to tone down or replace motions that would be problematic for users with certain disorders.
@cool_scatterРік тому
@@invinciblemode “unless stated otherwise” - but here you’re selecting based on “no preference”. It’s identical to disabling on prefers-reduced-motion in both form and function.
@ZhundahРік тому
There is an alternative way to do the staggering part if you don´t want to write a :nth-child() for every item. One could define an inline CSS variable in the html like style="--order: 1;" (2, 3, 4 and so on for every html element). Then in the CSS set a transition-delay of 'calc(100ms * var(--order))'. This works because the inline variable will be cascaded into the .logo class. This simplifies the staggering part in the CSS, but note that your target browser must support CSS variables.
@qubiРік тому
i was about to say that :D
@WACdeGРік тому
Or you could use counters, which has less boilerplate.
@fancybaguetteРік тому
a very cool and smart solution
@ko-DaeguРік тому
@@WACdeG best solution for this case
@94726Рік тому
@@WACdeG counter probably doesn't work in this case, as it returns a string value and therefore can't be used inside the transition-delay
@user-be3ri8gf1pРік тому
Your videos would never stop making me impressed. Such a knowledge portion in just hundreds of seconds...
@aredekerРік тому
Love these short but really helpful tutorials! For the 'npx serve' command it already was worth watching
@gergoradeczkiРік тому
I just noticed "defer" would sometime disappear around 1:44 Now I can't unsee it.
@devincheca9605Рік тому
Yeah the intersection observer is a lifesaver for this sort of thing. Good stuff. Love the tutorial.
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@billyrestelle27408 місяців тому
I've been looking for this for ages, thanks for sharing!
@ewnt9 місяців тому
Thank you for this awesome simple animation video. I'm currently creating my portfolio website from scratch and this will come handy !
@katymapsaРік тому
More of this please! Insanely good videos, thanks a lot for these.
@okoye.charlesРік тому
This is exactly what I have been looking for. I think this channel is living up to it's expectations. ☺️
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@filiplaskowski410Рік тому
Bro you are a fucking hero for making 5 min videos on these topics instead of making them 20 min with unnecessary filler. Thank you!!
@MrSama10002 місяці тому
Jeff, I just want to say thank you! Animations were the breaking point for me and you just made it soo easy. Top! 💯
@anton9410Рік тому
Pretty cool tutorial, simple and goes straight to the point!
@Tri-TechnologyРік тому
Well done. A tutorial I would have needed one month ago, Now I figured it out the hard way
@omarjimenezromero3463Рік тому
at least now you have a video to remember how to not go through all your memory and come here to do that XD
@micaelvieira6724Рік тому
if you can afford to use external libraries for this, framer-motion makes it really easy to have beautiful scroll animations
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@seanvinciРік тому
Subscribed! Fantastic tutorial. Super useful, to the point, with a hint of comedy. Looking forward to seeing more on this channel!
@michaelflevier76452 місяці тому
I love this, simple, clear and straightforward. This channel should be certified! well done!
@ShowmaticРік тому
I just learned about intersection observer a few months ago and man, I love it. It's been so useful ever since.
@vaisakhkm783Рік тому
i just learned html a few years ago ;) jk
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@ashtongeorge3984Рік тому
amazing tutorial, currently working on a personal website which is also my first web project since migrating from iOS development. I've been struggling with window position values and responsive layouts and this saves me a ton of work. THANK YOU!
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@micaelalgarrao6043Рік тому
Hey! I'm studying CSS and I have a doubt... How good at animations I need to be to land a job? Is it too important? I know the core of it but I'm not a pro.
@mike.12 місяці тому
Big change from drag & drop design 😂
@masoomsanadiРік тому
One of the very few videos. Simple to the point.
@NikSpringerРік тому
I’m still learning my way around CSS, HTML, and JS, which contributes to my lack of knowledge, however, I feel that if Fireship were to include the source code for videos like these, it would significantly help new learners like me.
@matthewrussell1027Рік тому
Fireship isn't really for new learners...unless they hear fast.
@vaibhavagrawal9399 місяців тому
@@matthewrussell1027 playback speed 0.75 is good for this channel
@dripcaraybbxРік тому
Finally something that isn't "Step 1, go download a library"
@KingPacavision7 місяців тому
Just started my portfolio website and this is exactly what I was looking for thank you 🙏
@petflaska38918 днів тому
Exactly what I needed and nothing more perfect!
@GyroCannonРік тому
I've done something similar to this but with interpolating a scroll position with an onscroll event and a position: sticky. The downside to the approach is that there's more JS, but the upside is that you can leave animations half finished if the user stops scrolling There's a Medium article about it (specifically, how to replicate the effect like it is on Apple's product pages) out there that shows exactly how it works.
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@gabriellengrvc9 місяців тому
do you have the link to the medium article please?
@duke605Рік тому
I'm a Senior Web Developer... Idk why I'm watching this... I found it entertaining none-the-less
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@vaibhavagrawal93910 місяців тому
Thank you for this amazing video, I have wasted my whole day for this scroll animation on internet but couldn't find any good thing. This video randomly popup in my youtube homepage and it made my work easier.
@ivan_offРік тому
Found out about intersection observer 2 years ago and I was very happy that I didn't actually have to use any kind of library for this simple task in every project, especially since learning something like Greensock isn't particularly easy. Thank you for this tutorial!
@shreyanshpatil830311 місяців тому
i made same in react and chakra ui and applied the same js the .show part it not working
@cementeriocluub11 місяців тому
@@shreyanshpatil8303 haha the same error, when I press the reload page, everything disappears
@nomadshibaРік тому
instead of *transition: all .5s* you can use *transition: .5s;* *transition-property: transform, filter;* and you can use a custom property instead of *.5s*
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@jackjackdevРік тому
If anyone is having trouble getting it to work in react (like i did for a sec) just wrap your JS in a useEffect hook :)
@thesunofodinРік тому
Thank you!! ❤
@SkanderrrrРік тому
I did nothing happens
@orliusРік тому
Still the best way to understand new stuff and clearly learn in few minute, you are splendid !!
@igormonteiro7039Рік тому
WOW!!! this was way more simple than expected! just added to my site! thank you a lot man!
@phatakomРік тому
Luckily I still have copilot cuz of Student pack.
@natyacodesРік тому
Same :D
@hunterbertoson156Рік тому
Same.
@islamibrahim8121Рік тому
Really?????
@_sevelinРік тому
But are you a student 🤔
@null_spacexРік тому
Same, seems like it will work forever 🤫🤞
@FjonanРік тому
One nitpick, you should avoid the 'all' for the transition. This will bite you in the behind in more complex stylesheets can lead to transitions for properties you don't want transitioned. And those transitions can be extremely bad on the render performance (like margins, dimensions and positions that don't use transform). I made it a habit to always explicitly define the transitioned properties in the transform rule.
@AnselwithmacРік тому
Ahh see Im new to JS, but not to programming. I was wondering this as well as I was making a lot of transitions. What do you prefer to do instead? Today I made a navigation bar that fills the whole top of the page, and as the user scrolls down, the nav bar "pops" out and shrinks to be more of a floating element. But I also noticed when the page first loads, the nav bar shifts into place due to the transition all.
@FjonanРік тому
@@Anselwithmac most of the time you can do what you need with good performing properties like transform which offers rotation, positioning and scaling. Only if this does not cover what you need you should start to transition other stuff. For example if the navbar "pops out" you could fade the content out (really fast like 0.15s) and then shrink it using transform: scale. It sure requires extra work to avoid transition: all but gives you that extra bit of resilience.
@CheosFactionРік тому
I would love to see more cool tutorials like this.
@JBurky15Рік тому
Easy scroll anims AND centering a div! Well, color me impressed. I'll definitely be trying this out on my next project
@NateLevinРік тому
To reduce code duplication for the animation staggering you can use CSS counters combined with calc(), right?
@poolkrooniРік тому
Another small improvement besides the reduced motion preference would be to account for no-JS users and have some ".no-js" class on the body that reveals all the hidden elements. Otherwise atm everything would remain hidden.
@wayneswildworldРік тому
What percent of people don't have JS these days?
@poolkrooniРік тому
@@wayneswildworld You're thinking of the most average user, but also think about parsers visiting the site and only grabbing the visual elements, some kiosk-mode machines with limitations or library computers or whatnot. This is a simple best practise that will allow you to universally reach a wider audience. Also some of my friends have JS off by default and only allow it for a limited number of trusted sites, those people also exist and that's okay 🤷♀
@wayneswildworldРік тому
@@poolkrooni So what should you do in an instance where you are hiding an element with js? I am not familiar with this issue?
@poolkrooniРік тому
@@wayneswildworld I most likely would keep it visible. Depends on the specific scenario, you can sometimes just move toggling over to CSS or not have interaction on the non-js version
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@lina_usecheРік тому
Such an amazing tutorial! Thank you so much!!
@yashhhh8012Рік тому
observer is one of hardest topics but your way of explaining makes it easy to Understand. 🙌
@crowlsyongРік тому
You are so good at making these videos. Thank you. Do you have github project for this? If so, can you link it?
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@dl0.0lbРік тому
Great and succinct. It would be nice if you could combine the `n` in nth-child and calc() to do something like `.logo:nth-child(n) { transition-delay: calc(200ms * n); }` . Maybe someday.
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@sam-u-el9 місяців тому
now that was simple, direct, and awesome.
@kelvink96Рік тому
I have been looking for this for months now. Thanks for sharing 👍👍👍
@invertcodeРік тому
It's also nice to use inline css variables, fe. style="--delay:300ms", that way we don't need to worry about writing separate css for each element. Obviously classes (fe. .delay200) would work the same
@mityaboy4639Рік тому
especially if the number of elements are dynamically generated- so you either run out of classes ready or you need to generate them (with the nth option) the inline variable is the best option as it can be generated on the fly and a simple css line can take care of the delays based on the variable :)
@i_Mordercag17 місяців тому
It's really sad to read his "hi mom" and secret messages for his mom after the sad day:(
@rounaksen1683Рік тому
didn't expect the animation code to be small like this. I is wonderful what you can achieve using vanilla Javascript .
@ramtejeshm93449 місяців тому
Seriously amazing content
@BlueJDevРік тому
Thought it might be worth noting that you shouldn't hide elements by default in the real world. Might be a good idea to use a custom attribute for the observer then hide each element, add the hidden class, on load with the JavaScript, as we're already using it. This way you won't exclude those that have JS disabled by default (a small number I know, but some crawlers struggle with JS) Of course there's many other ways to do this as well, like noscript.
@PenguinCrayon269Рік тому
i conditionally disable js on bloated website 👍
@matheusgoulart1618Рік тому
I don't think for the crawlers it makes much of a difference if it's hidden or not since they tend to not take a lot of css into consideration. For users, if they have JS disabled, you can just have a noscript tag saying you need JS, like in a blank React app.
@BlueJDevРік тому
@@darkpain4208 hey, you wouldn't be able to have animations applied on scroll without JS, so if someone has JS disabled on their browser and they visit your site, using the code in the video, the user would never see any content that has the "hidden" class set by default as JS would not run and remove the hidden class on scroll. If every item is animated your page would essentially be blank. So I would use an attribute like bluej-scroll-anim="true (or name of animation class)" on any element needing animate on scroll in, then target that attr in JavaScript, finding all ("[bluej-scroll-anim]") and setting class hidden (if not in view) on load in JS, before activating the "scroll" observer on the set of elements.
@BlueJDevРік тому
@@matheusgoulart1618 true, a lot of sites are JS based nowadays so it is quite a small consideration. Would just be shame to have some users not see important elements on the page just because I added animation to it. Yeh, I suppose if a crawler considers CSS these days it's likely to take into account js too..
@darkpain4208Рік тому
@@BlueJDev Thanks so much!
@pixiedevРік тому
What if js is disabled 🤔. Same as you teach I done yesterday. but I didn't add hidden class by myself. I add .reveal-anim select all the .reveal-anim when it will not intersecting it will add hidden class to the element and if intersecting it will remove. and if js is disabled all elements where visible in my case.
@pokefreak2112Рік тому
Good catch, another solution would be to use the Web Animations API so you don't have to worry about CSS breaking the noscript case
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@toulasanthaРік тому
Awesome job mate. Love the flawless delivery. 👍
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@TheTutosurtout9 місяців тому
Big up man, i loved the video. Concise, precise and elegant.
@ariansharifi9682Рік тому
Perfect, i was just wondering how to do this for my react website
@AidanLyonРік тому
Me too. Can anyone advise?
@aelxxsРік тому
@@AidanLyon framer motion works great for react
@zadeviggersРік тому
The issue with this is that it doesn't work when JavaScript isn't available. A progressive enhancement approach like this would be better: Have all the elements shown by default. When the JavaScript runs, the intersection observer can add a class to hide all of the non-visible elements, without affecting the already visible content. While this does mean that you lose the ability to have animations on any content over the fold (there would be a slight flicker, which isn't acceptable), I think the benefit of the content being accessible to a larger audience is worth it.
@mszoezo6368Рік тому
Wouldn't it be better to have css inside a tag to force show everything?
@zadeviggersРік тому
@@mszoezo6368 that seems like it would be more complicated than using an extra class. If it's using multiple classes you don't like, a custom attribute would work well - I was originally going to suggest that in my comment but I decided to use classes for the sake of simplicity
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@eotikuracРік тому
omg the js not available people are still among us
@DKSubconscious11 місяців тому
For none JS then the hidden class shouldn’t work with zero animations. Most people have JS on and we found most people using screen readers have JS turned on too.
@remoreacts91Рік тому
I was literally looking for how to do this! Amazing timing
@alialsaady5Рік тому
Thank you for the clear explanation
@Peter-yd2okРік тому
Is there an easy way to implement smooth scroll or locomotive scroll?
@peterszarvas94Рік тому
html { scroll-behavior: smooth; }
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@phatakomРік тому
1:12 poor IE 🙃
@alfredogonzalez9420Рік тому
Poor? Screw IE, it can be called A explorer not a modern explorer, with their shitty support and now it's dead and buried, gg.
@phatakomРік тому
@@alfredogonzalez9420 lol
@codernerd7076Рік тому
It's dead
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@Migsfigs10 місяців тому
Great video, concise and short yet descriptive
@nicolasbava346718 днів тому
BOMBASTIC!!! thank you very much, working properly in next js framework
@bestfacebookcover9348Рік тому
For staggering this can be useful as well if you need more control over the delays: .d1{transition-delay:100ms} .d2{transition-delay:200ms} .d3{transition-delay:300ms} .d4{transition-delay:400ms} .d5{transition-delay:500ms} .d6{transition-delay:600ms} .d7{transition-delay:700ms} .d8{transition-delay:800ms} .d9{transition-delay:900ms}
@DavidlavieriРік тому
and with sass even better
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@dandcodesРік тому
Great video love the more in depth content. TL;DR: I know this is a demo site so this comment is only meant for larger projects. Put the script tag in the element with a defer attribute Regarding your placement of your script tag at the end of the body element, doing this may cause a document reflow due to the HTML/CSS already being parsed before the JS file is read; as the browser isn't aware if loaded JS is going to modify a DOM element. A more modern alternative is to place your script tag in the head of the docuemnt but you will need to add a "defer" tag to it as shown in this video to ensure it isn't render blocking as shown in this video ukposts.info/have/v-deo/m4ioooCCnaKpwqc.html
@cuuyРік тому
How does defer prevent reflow exactly? Script with defer will still get executed only after the document has been parsed?
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@leog1676Рік тому
This is a great video, thank you! Concise and informative. My kind of content!
@1ekkРік тому
Good job dude! Hope you gonna make more videos like this one. 👍🏿
@4.0.4Рік тому
I'll just say something. Going too far with customizing basic stuff like scrolling behavior is sometimes overdone, and becomes gaudy and invasive, like custom cursors or scrollbars of the past.
@isheanesunigelmisi8400Рік тому
🎉 Animations so cool that you forget that GitHub is training copilot on stolen code
@CUBKITSРік тому
Fellas, is reading someone else's code stealing it?
@majoralterРік тому
How do you even steal code
@NanagosРік тому
What else should Github Copilot train on? Only on closed source code made by Microsoft?
@omarjimenezromero3463Рік тому
@@Nanagos hahahahahhaa i would like to watch how copilot crash like the blue screen of death every time i want to center a div XD.
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@szymonszewcjrРік тому
This kind of content is so good. Give us more
@fluoriteРік тому
exactly what I needed
@tanviralamsyed917211 місяців тому
this really elevated my website, thank you for the easy tutorial
@harmonictuneytРік тому
Beautiful, just beautiful, thank you :)
@carolinaangelicasandovalag818Рік тому
Amazing work on the explanation, trying it definitely
@kushlalve20816 місяців тому
Thank you so much for this tutorial , it was so helpful my website looks much classy now
@CondeAlbertoРік тому
Grid FTW always. Brilliant! Keep them videos coming.
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@SakinukasРік тому
Appreciate your tutorial! Makes scrolling way more intuitive.
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@SmartC2007Рік тому
Thanks a lot. Well done and easy to understand!
@paulaneesh7Рік тому
I actually have used this in my portfolio site but with scroll behaviour smooth upon when the element is about to appear but the one you showed here is better, I will try to use this one from now
@elhaambasheerch7058Рік тому
Jeff is the only coding guy who makes learning stuff fun, hats off
@carloscorgozinho53534 місяці тому
Great video, fast and clean explanation. Just the way I like it. Thanks ;)
@yemam4156Рік тому
Nice Video and straight to the point
@adrielmwofoh911113 днів тому
Hey jeff, cool video, Straight and concise. Thanks man.
@systemghost10Рік тому
amazing video I had always wondered how they got that effect! Thank you
@rickfuzzyРік тому
Amazing video, feel like i just leveled up big time. Looking forward to watching your other content.
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@jasonfloyd5225Рік тому
Congratulations! This is the very first YT video I’ve ever set the playback speed to *less* than normal. Good stuff.
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@DanielDogeanuРік тому
Will definitely use this in my next project! 😁
@ashimxtha6407Рік тому
thank you for the information much appreciated
@Kechi.e10 місяців тому
Thank you!!! you've helped me so much!
@ahmadrezadorkhah9574Рік тому
bruh thanks a lot. I've been looking for this.
@andrew-does-marketingРік тому
Such a great guide. You are a good content creator. Keep it up!
@jlunardiРік тому
Very cool Jeff! I did not know about the Intersection observer - appreciate the learn!
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@michaelsolomon60332 місяці тому
This is great, thank you so much
@Ukr_sunflowerРік тому
Thank you so much for your tutorial! It’s so helpful
@dofxoРік тому
literally one of the best tuts I've ever seen lately ❤🔥
@charusharma7872Рік тому
animated Box With CSS ukposts.info/have/v-deo/n3KerGmJpIqZpXk.html
@nguyenngocduy629Рік тому
So thankful for this
@mikhalpalychРік тому
Absolutely useful and so easy, thanks mr youtuber
@TheDragShotРік тому
Now this is some nice wisdom. Thanks a lot! 👍
@N0TZ3R0Рік тому
Man that's awesome, thank u so much, appreciate it
@estacaotech9 місяців тому
Its kinda weird to say but for some reason when my code works and/or I learn a new thing (even when I copy from the internet) I get chills of happiness and motivation haha