Holy moly, I ran in the exact same problem last week. A calendar in react marked my query range but also the init range, because the timing of the useEffect was terrible. My stupid solution was a chained useEffect (first useEffect changes a helper value and nothing more, which triggert a second useEffect only for this value and put my parameters in the components). I think I will give useLayoutEffect a try if I have to change the application again. Thank you for the video.
I had same requirement to implement and I was about to loose my mind because it was not working out, until I came across your video. Thank you very much WebDevSimplified !!!
New to react here... I've been using useEffect in the tutorials I've been taking but I didn't understand what exactly it did. I mean the name kind of explains it, but I didn't fully grasp what it did, 30 seconds into this video and I'm like "ohhhh! 🤦" Thank you!!!!
For those learning this in react 18, you will not get this inconsistency because in react 18 useEffect will run synchronously when it is as a result of discrete user input such as a click.
Thanks for the heads up, was going mad trying to reproduce this scenario. Wrapping in setTimeout (moving it outside of the event handler task), will cause it to behave as per the video e.g. onClick={() => { setTimeout(() => { setShow((prev) => !prev); }, 0); }}
You will not be able to see the change in the position of the text when you use useEffect. This is because of the part where he says, "I am going to slow this down" without explaining how. You should simply add a "debugger;" statement instead as the first line of your "useEffect" callback. That will pause the execution and allow you to see the initial rendering. This actually raises another question: The explanation in this video gives the impression that "useLayoutEffect" will render at the appropriate place without any moving around of the text because it is called before painting. If you add a "debugger;" statement as the first line of your "useLayoutEffect" callback, you can see the initial placement (which means a paint has occurred already). I did not use .
Why does the component rerender after setting the new top parameter? I get that it rerenders after the onClick, but then, after the useEffect runs and changes the top value, it renders again, why if there's no state change?
Yes react re-renders the component when state changes only. But here, we directly accesses the underlying dom element and changed its properties, as described in useRef, ref always has access to underline DOM element. it’s basically like getting that element by query selecting it. eg const element = document.querySelector(“.modal”) ; So basically this element is equal to the element ref has access to. And ofcourse every direct change we make to DOM element will reflect on browser, doesn’t matter if react is rerendering it or not.
I have one problem in react actually currently working on a project where they have dynamic bundles or cdn links which add some header and footer in our react app but I need to add some event listeners or doing some DOM manipulation on them dynamically but the problem is that html element come from different bundles Or application and I didn't have an access to those html elements from our react app so I can't add ref on those elements so can I do direct Dom manipulation on element because I read don't directly manipulate DOM because react working on virtual DOM any other solution ?
@@ishananaguru we can't import them as component it's actually a cdn links or bundle links which add header and footer in mine application Something like bootstrap cdn which add some style in application but we can't manipulate there code directly
i thought, useEffect is equivalent to componentDidUpdate and useLayoutEffect is equivalent to componentShouldUpdate, and i use these for certain scenarios, omg
One thing YOU NEVER EXPLAINED and probably confuse ALOT of people and deceives alot too. the JSX is render BEFORE the useEffect normal behavior. I've struggle like hell because most Tuto doesn't even explain this simple concept. and I'm the f***ing noob.
Holy moly, I ran in the exact same problem last week. A calendar in react marked my query range but also the init range, because the timing of the useEffect was terrible. My stupid solution was a chained useEffect (first useEffect changes a helper value and nothing more, which triggert a second useEffect only for this value and put my parameters in the components). I think I will give useLayoutEffect a try if I have to change the application again. Thank you for the video.
mine problem was just today. had to fix in another way
I had used this for a project where I needed to set css properties in the component itself. Very useful hook for some niche cases.
Спасибо. Более подробного и компактного объяснения не встречал. Как всегда четко и по делу.👍
Synchronous use Effect 😍😍😍
I have some places this will definitely feel home.
Thanks Kyle
as usual extremely simple and clear explanation
I had same requirement to implement and I was about to loose my mind because it was not working out, until I came across your video. Thank you very much WebDevSimplified !!!
This thing couldn't be explained better, thank you 👏
New to react here... I've been using useEffect in the tutorials I've been taking but I didn't understand what exactly it did. I mean the name kind of explains it, but I didn't fully grasp what it did, 30 seconds into this video and I'm like "ohhhh! 🤦" Thank you!!!!
Kyle, yet another extremely simple and ultra useful explanation!!! Thank you!!!
thanks for this very helpful explanation. your react hooks playlist is awesome!
Many tried... but you did it! Thank you for making me understand this!
spend 20min reading and trying to understand this, and Kyle just explain it to me in a 4 min video at playback 1.5x speed LOL Thank you Kyle!
So if it's related to something visible to the UI (layout), we use useLayoutEffect. It's interesting..... Thank you man 😉
Great video, very clear and helpful-thank you so much!
Lot of clarity in very little time. 🥂✨
I can feel the effect of this already
useFeelEffect
@@amdinside5383 touché lol
in 5 minutes i found out all what i need. Thanks
Perfectly explained , thank you !
Kyle, thanks for your explanation will never forget the difference now :)
Best example and best explanation
hats off to this example!
Thanks for the explanation Kyle, learning React in 2022!
Damn I actually learned it in 5mins!
thank you for this amazing explaination and for putting the right useCase for useLayoutEffect hook
Very clear explanation of why one would use the useLayoutEffect hook over the useEffect hook. Thanks, Kyle
{2021-11-16}
Awesome explanation 🎉
nice explanation! I really needed this hahaha
Super useful, thanks! Could have used it in one of my projects 😄
Explained it beautifully
This is dope !
I now have a previous project to fix 😄
beautifully explained !!
Thank you for your videos. They are really helpful.
You are the best! I really like your videos :)
This was new to me, thanks!
Hey superhero! Is there any plan to upload featherjs course in future?
For those learning this in react 18, you will not get this inconsistency because in react 18 useEffect will run synchronously when it is as a result of discrete user input such as a click.
Thanks for the heads up, was going mad trying to reproduce this scenario. Wrapping in setTimeout (moving it outside of the event handler task), will cause it to behave as per the video e.g.
onClick={() => {
setTimeout(() => {
setShow((prev) => !prev);
}, 0);
}}
It also helps if you throttle your CPU in chrome
HAL-AY-LOO-YA! Thank you so much a. for explaining this so well that i got it first time and B fixing all my animations!
Amazing info mate, thanks!
At what point does our refs get associated to the dom elements? Does it happen before the execution of useLayoutEffect?
before painting useLayoutEffect runs and before that rendering of DOM elements happens I guess At that point refs get associated.
You explained it so well
Great explanations
wow! its so ez & clear to learn from you :D
thanks bro, great video!!!
Nice, please make a video on React Router DOM V6 for Authentication and Protected Routes
in react18, there are same when use these 2 hooks, it doesnt have a position change use useeffect, same as using uselayouteffect
cool explanation thanks
Good demo. Thanks.
How did they handled this use case before useLayoutEffect ?
Totally loved it
So much clarity
You will not be able to see the change in the position of the text when you use useEffect. This is because of the part where he says, "I am going to slow this down" without explaining how.
You should simply add a "debugger;" statement instead as the first line of your "useEffect" callback. That will pause the execution and allow you to see the initial rendering.
This actually raises another question: The explanation in this video gives the impression that "useLayoutEffect" will render at the appropriate place without any moving around of the text because it is called before painting. If you add a "debugger;" statement as the first line of your "useLayoutEffect" callback, you can see the initial placement (which means a paint has occurred already). I did not use .
Your video do what other 5 previous didn't, that I know what is layout effect
Thank you so much sir ❤️
interview-quality example)
Why does the component rerender after setting the new top parameter? I get that it rerenders after the onClick, but then, after the useEffect runs and changes the top value, it renders again, why if there's no state change?
Yes react re-renders the component when state changes only.
But here, we directly accesses the underlying dom element and changed its properties, as described in useRef, ref always has access to underline DOM element.
it’s basically like getting that element by query selecting it.
eg
const element = document.querySelector(“.modal”) ;
So basically this element is equal to the element ref has access to.
And ofcourse every direct change we make to DOM element will reflect on browser, doesn’t matter if react is rerendering it or not.
@@arjobansingh1940 Oh I see, thanks!
Excellent question!
This is wonder full
nice example 👍
Finally a worthy tutorial!
Can you talk about forwardRef? Thank you.
I have one problem in react actually currently working on a project where they have dynamic bundles or cdn links which add some header and footer in our react app but I need to add some event listeners or doing some DOM manipulation on them dynamically but the problem is that html element come from different bundles Or application and I didn't have an access to those html elements from our react app so I can't add ref on those elements so can I do direct Dom manipulation on element because I read don't directly manipulate DOM because react working on virtual DOM any other solution ?
if you import them as components you can set ref attribute to them I think.
@@ishananaguru we can't import them as component it's actually a cdn links or bundle links which add header and footer in mine application Something like bootstrap cdn which add some style in application but we can't manipulate there code directly
Easy explained.
thanks mate!
So uselayouteffect runs after commiting to the ui after re render
I mean.............I just love you man
Amazing!
Why not use useEffect only and toggle visibility using css display?
I always love to see Leonardio DiCaprio in his young! great content!
Thank you
Thanks
his hair are more clear than my life
ahh i got the idea .now, where and how to useEffect and UseLAyout
I thought I had my playback speed increased suddenly xD
How to use useLayoutEffect hook in react-plotly
Have I been saying "measurements" wrong?
loooool
Only *useImperativeHandle* left to be explained! 😎
Guess this is why we get those annoying height jumps if we try to animate height?
useful!
Didn’t know Andrew Garfield Spiderman can code
Just your friendly neighborhood coder
beautiful
Great
I thought I was watching at 1.25 speed :P
i thought, useEffect is equivalent to componentDidUpdate and useLayoutEffect is equivalent to componentShouldUpdate, and i use these for certain scenarios, omg
Maysurmints 😂 love these videos 💪
One thing YOU NEVER EXPLAINED and probably confuse ALOT of people and deceives alot too.
the JSX is render BEFORE the useEffect normal behavior.
I've struggle like hell because most Tuto doesn't even explain this simple concept.
and I'm the f***ing noob.
Hi
why 5minutes 😭 but thank you
✅✅✅❤️
Your talking speed is very fast pls do slow speak speed!!
excellently, the only one i cant satisfied is your speaking is too fast 😂
Second!!
Firsttttttt
No semicolons noooooooooooo
You explain to fast... sadly
Hii i am from India there is night 10.30 pm what is your country time tell me plz
Stop posting bullshit comments🤦🤦
@@HarshSingh-hk8fe bro I want to know that where he is live
Hey kyle do check your email. I love your way of teaching. Are you getting married anytime soon? 💔
good but as i know manipulating dom by the normal way like (style.top) is anti-pattern
How would you accomplish this without a style attribute?
Thanks
Great
Hi
Thanks
You are very welcome! Thanks for the support!