-
Notifications
You must be signed in to change notification settings - Fork 186
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Question] How would you handle conditional rendering with hooks? #162
Comments
That's interesting! Thanks for the detailed description. |
The question is, how to handle when the
It needs to handle observering and unobservering whenever it changes. |
I'm currently leaning towards throwing an error if the Looking at your example, i think it would make sense for you to create a The reason is you aren't actually using the hook before you load the content. |
makes sens @thebuilder. May result in a pretty superficial component, but it does seem like the right solution (and certainly the easiest). Feel free to close this issue. |
I looked a bit more into how to solve this, and made a solution that recreates the observer when the https://github.com/thebuilder/react-intersection-observer/blob/master/src/hooks.tsx#L25
It seems like a more robust solution, that's less likely to cause surprises. Also had a coworker with a similar issue last week, so it seems like a common enough use case. |
elegant |
The
|
@raRaRa That's the problem, the hook won't trigger when I made a blog post about how I solved this issue - Using a ref callback instead of |
Ah wow, good catch! Thanks :) |
You also shouldn't really worry about running an inexpensive |
I had an issue with moving the ref to a child component, but it looks like you already thought of that and handled it with callback refs in the new |
Sorry to post on a closed issue. I think I have an error directly related to this. I am unable to solve it. The question is on stackoverflow - React state is always one step behind while making predictions on uploaded image using Tensorflowjs. I'm using |
Hey man, thanks for the article! I have an use case that I need to pass back some things back to the main component from the component that have ref. Usually I could achieve that using the useImperativeHandle hook but I couldn't make it work with this solution. I have something like:
My problem is that I need some values from inside C2 to use on C1 and make it render on changes. |
First, I'd like to say thank you for such a great tool. Very useful.
I ran into a situation I wanted to run by you, and see if you have any suggestions.
This is specifically when using functional components with conditional rendering.
Consider the following scenario:
In the above example,
ref.current
won't exist for the initial render. When the effect is run inuseInView
, it will fail to attach the observer.When the
isLoading
state changes, a re-render will happen. However, theuseInView
effect is only run if one of the options changes.Even if we add
ref.current
to the dependency array in the effect, this doesn't help. The reason being, the dependencies are checked against at the time of render, whereas react refs get modified after rendering. See facebook/react#14387 (comment).If we remove the list of dependencies entirely, we can see the
ref.current
has the proper reference inuseEffect
on the subsequent render. This is because the hook execution is deferred until after render (and thus the reference has been updated). However this results in an infinite render loop for this scenario. This may be the reason you added dependencies touseEffect
to begin with.I apologize for not coming forward with a potential solution, but this one stumped me. useLayoutEffect doesn't help us here either, because the
inView
state is set asynchronously.One "workaround" is to always include the ref in the rendered component, i.e.
However, this is not ideal and comes with its own set of pitfalls/challenges.
It may also be worth noting that this is a non-issue when using render props, since the ref is guaranteed to exist when the observer is attached.
The text was updated successfully, but these errors were encountered: