-
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
Remove object-assign polyfill #10280
Conversation
I potential difference in this case from others is that Babel will include its _extends polyfill anyway, it seems like a waste to not use it for this case? It may not be a perfect polyfill but I'd be surprised if that matter here |
Talking about this specifically, as a replacement for the extra code. https://babeljs.io/docs/plugins/transform-object-assign/ |
Why will Babel include it? I’m not sure I’m following. Do you mean we already have it in our builds? I would expect that not but maybe I’m wrong. |
sorry I should re-phrase that :P, its an internal help babel inlines for a few general transforms, You can see it in react-dom@16 doing a find for Since it's already there, you can use the linked transform to change Object.Assign references to use that instead. It doesn't actually polyfill anything, it works like the plugin you are removing but uses the core babel helper. |
The funny thing is that it looks like the Babel transform is deferring to this polyfill lol. It is normally |
Seems like it's used in just one place, we can probably remove that. |
Or better yet, configure Babel to always use real |
sure, easy enough maybe to avoid it, but it seems like an easy win for folks to not have to install another package, add another line to their entry (before React) etc. On an unrelated note is there an issue tracking warning for things that need to polyfilled? I ran into this trying to test ie9 on the fixture app the other day. I got a hard error for Set and Map missing instead of the more normal "Hey react requires this, here is where you can install a polyfill" |
The plan is to document new required baseline (just like it was the case before ES5 became supported everywhere). We will probably require Similar to https://facebook.github.io/relay/docs/relay-modern.html#javascript-environment-requirements. |
We have an invariant check for |
Yeah, we could. Do you want to send a PR? |
No code should be relying on the exact order of object properties though, so this should be safe. |
Our own code was—because we used to compare checksums for markup generated on the server and on the client. But we don’t anymore. |
For inline styles hydration warning we still rely on enumeration order I think. Because we generate a compatible string that we compare against the attribute. |
Ah, I see. Another downside of this is it makes IE11 incompatible which otherwise meets our requirements for minimal target. Let's wait with this until 17. |
Since we already depend on
Map
andSet
I figured we might as well ask users to polyfillObject.assign
if they need to.In browsers, it's still not supported everywhere (e.g. IE 11 doesn’t but Edge does). There is a precedent: Relay Modern, Preact, Inferno don’t ship with it. Many Redux apps use
Object.assign
so users resort to polyfilling it anyway.In Node, there was an issue with bad
Object.assign
implementation in some Node version that caused different attribute order. But Fiber is resilient to that so it wouldn’t be a problem anyway.Test plan: packaging fixtures work. For internal FB bundles, we didn’t use it in the first place (because we had our own polyfill).