-
Notifications
You must be signed in to change notification settings - Fork 47.3k
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
Problem with unstable_renderSubtreeIntoContainer and refs #9808
Comments
It's a bit hard for me to figure out what's going on there, but in any case we're going to eventually drop You can see a working example using I'll close because it's unlikely we'll change |
@gaearon Thanks for the following up. We will try to refactor the portal implementation (using |
I don't think there is any regression there, is there? It seems like the example in this issue is with 15.4.x. So Fiber does not change the behavior there. |
I'm not sure it's a regression either, it could be an edge case making it work with 15.4.x but not with the pre-release version. Still, we have noticed a breaking-change on the Material-UI project. We have that open issue for more reference mui/material-ui#7025. Will dig more into it. |
I’m still confused. Are you saying there is a React version where https://jsfiddle.net/cassln/cusus029/2/ (which uses 15.4, not Fiber) ever worked? Or are you saying there is a different similar issue? |
I have managed to reproduce what we experience with a simple jsfiddle demo. mui/material-ui#7025 (comment) The behaviour definitely changed between latest (v15.6.1) and next (16.0.0-alpha.13). However, that's most likely not important as affecting a unstable API that is going to have a first class one on the fiber version. @gaearon Thanks for the support. |
Do you want to request a feature or report a bug?
Report a bug.
What is the current behavior?
I use the usual technique of portals with unstable_renderSubtreeIntoContainer. Also I need to control portal children with
refs
(using legacy syntax I know).The problem is
unstable_renderSubtreeIntoContainer
is async and can be called aftercomponentDidUpdate
. When refs are used incomponentDidUpdate
, they can be undefined due to async nature ofunstable_renderSubtreeIntoContainer
.If the current behavior is a bug, please provide the steps to reproduce and if possible a minimal demo of the problem via https://jsfiddle.net or similar (template: https://jsfiddle.net/84v837e9/).
Demo. Open the browser console and press "add" button. You will got this error:
It causes because of, according to logs
componentDidUpdate
called beforeunstable_renderSubtreeIntoContainer
callback.What is the expected behavior?
Are needed defined
refs
incomponentDidUpdate
. In the general case, a completely completed render.I know about pattern with using
unstable_renderSubtreeIntoContainer
callback, but this is not preferred solution. Because of I have quite complex combination of two libraries and don't have access tounstable_renderSubtreeIntoContainer
callback. If someone is interested in libs, this is react-autocomplete and react-tether.There may be a way with avoiding rerender and saving the refs from the first render?
Which versions of React, and which browser / OS are affected by this issue? Did this work in previous versions of React?
I'm using v15.4.2.
The text was updated successfully, but these errors were encountered: