Commit e25fbfb
committed
Allow Float methods to be called anytime in Fiber
Previously we restricted Float methods to only being callable while rendering. This allowed us to make associations between calls and their position in the DOM tree, for instance hoisting preinitialized styles into a ShadowRoot or an iframe Document.
When considering how we are going to support Flight support in Float however it became clear that this restriction would lead to compromises on the implementation because the Flight client does not execute within the context of a client render. We want to be able to disaptch Float directives coming from Flight as soon as possible and this requires being able to call them outside of render.
this patch modifies Float so that its methods are callable anywhere. The main consequence of this change is Float will always use the Document the renderer script is running within as the HoistableRoot. This means if you preinit as style inside a component render targeting a ShadowRoot the style will load in the ownerDocument not the ShadowRoot. Practially speaking it means that preinit is not useful inside ShadowRoots and iframes.
This tradeoff was deemed acceptable because these methods are optimistic, not critical. Additionally, the other methods, preconntect, prefetchDNS, and preload, are not impacted because they already operated at the level of the ownerDocument and really only interface with the Network cache layer.1 parent 8e74775 commit e25fbfb
File tree
3 files changed
+79
-118
lines changed- packages
- react-dom-bindings/src/client
- react-dom/src
- __tests__
- client
3 files changed
+79
-118
lines changedLines changed: 27 additions & 100 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1939 | 1939 | | |
1940 | 1940 | | |
1941 | 1941 | | |
1942 | | - | |
1943 | | - | |
1944 | | - | |
1945 | | - | |
1946 | | - | |
1947 | | - | |
1948 | | - | |
1949 | | - | |
1950 | | - | |
1951 | | - | |
1952 | | - | |
| 1942 | + | |
1953 | 1943 | | |
1954 | | - | |
1955 | | - | |
1956 | | - | |
1957 | | - | |
1958 | | - | |
1959 | | - | |
| 1944 | + | |
1960 | 1945 | | |
1961 | 1946 | | |
1962 | 1947 | | |
| |||
1979 | 1964 | | |
1980 | 1965 | | |
1981 | 1966 | | |
1982 | | - | |
1983 | | - | |
1984 | | - | |
1985 | | - | |
1986 | | - | |
1987 | | - | |
1988 | | - | |
1989 | | - | |
1990 | | - | |
1991 | | - | |
1992 | | - | |
1993 | | - | |
1994 | | - | |
1995 | | - | |
1996 | | - | |
1997 | | - | |
1998 | | - | |
1999 | | - | |
2000 | | - | |
2001 | 1967 | | |
2002 | 1968 | | |
2003 | 1969 | | |
| |||
2012 | 1978 | | |
2013 | 1979 | | |
2014 | 1980 | | |
| 1981 | + | |
| 1982 | + | |
| 1983 | + | |
| 1984 | + | |
2015 | 1985 | | |
2016 | 1986 | | |
2017 | 1987 | | |
2018 | 1988 | | |
2019 | 1989 | | |
2020 | | - | |
2021 | | - | |
| 1990 | + | |
| 1991 | + | |
2022 | 1992 | | |
2023 | 1993 | | |
2024 | 1994 | | |
| |||
2040 | 2010 | | |
2041 | 2011 | | |
2042 | 2012 | | |
| 2013 | + | |
| 2014 | + | |
| 2015 | + | |
2043 | 2016 | | |
2044 | 2017 | | |
2045 | 2018 | | |
| |||
2067 | 2040 | | |
2068 | 2041 | | |
2069 | 2042 | | |
| 2043 | + | |
| 2044 | + | |
| 2045 | + | |
2070 | 2046 | | |
2071 | 2047 | | |
2072 | 2048 | | |
| |||
2102 | 2078 | | |
2103 | 2079 | | |
2104 | 2080 | | |
| 2081 | + | |
| 2082 | + | |
| 2083 | + | |
2105 | 2084 | | |
2106 | 2085 | | |
2107 | 2086 | | |
2108 | | - | |
| 2087 | + | |
2109 | 2088 | | |
2110 | 2089 | | |
2111 | 2090 | | |
| |||
2163 | 2142 | | |
2164 | 2143 | | |
2165 | 2144 | | |
| 2145 | + | |
| 2146 | + | |
| 2147 | + | |
2166 | 2148 | | |
2167 | 2149 | | |
2168 | 2150 | | |
| 2151 | + | |
2169 | 2152 | | |
2170 | 2153 | | |
2171 | 2154 | | |
2172 | 2155 | | |
2173 | 2156 | | |
2174 | 2157 | | |
2175 | 2158 | | |
2176 | | - | |
2177 | 2159 | | |
2178 | | - | |
2179 | | - | |
2180 | | - | |
2181 | | - | |
2182 | | - | |
2183 | | - | |
2184 | | - | |
2185 | | - | |
2186 | | - | |
2187 | | - | |
2188 | | - | |
2189 | | - | |
2190 | | - | |
2191 | | - | |
2192 | | - | |
2193 | | - | |
2194 | | - | |
2195 | | - | |
2196 | | - | |
2197 | | - | |
2198 | | - | |
2199 | | - | |
2200 | | - | |
2201 | | - | |
2202 | | - | |
2203 | | - | |
2204 | | - | |
2205 | | - | |
2206 | | - | |
2207 | | - | |
2208 | | - | |
2209 | | - | |
2210 | | - | |
2211 | | - | |
2212 | | - | |
2213 | | - | |
2214 | | - | |
2215 | | - | |
2216 | | - | |
2217 | 2160 | | |
2218 | 2161 | | |
2219 | 2162 | | |
2220 | | - | |
| 2163 | + | |
2221 | 2164 | | |
2222 | 2165 | | |
2223 | 2166 | | |
| |||
2236 | 2179 | | |
2237 | 2180 | | |
2238 | 2181 | | |
2239 | | - | |
| 2182 | + | |
2240 | 2183 | | |
2241 | 2184 | | |
2242 | 2185 | | |
| |||
2252 | 2195 | | |
2253 | 2196 | | |
2254 | 2197 | | |
2255 | | - | |
2256 | 2198 | | |
2257 | 2199 | | |
2258 | 2200 | | |
| |||
2269 | 2211 | | |
2270 | 2212 | | |
2271 | 2213 | | |
2272 | | - | |
| 2214 | + | |
2273 | 2215 | | |
2274 | 2216 | | |
2275 | 2217 | | |
| |||
2284 | 2226 | | |
2285 | 2227 | | |
2286 | 2228 | | |
2287 | | - | |
| 2229 | + | |
2288 | 2230 | | |
2289 | 2231 | | |
2290 | 2232 | | |
| |||
2297 | 2239 | | |
2298 | 2240 | | |
2299 | 2241 | | |
2300 | | - | |
| 2242 | + | |
2301 | 2243 | | |
2302 | 2244 | | |
2303 | 2245 | | |
| |||
2308 | 2250 | | |
2309 | 2251 | | |
2310 | 2252 | | |
2311 | | - | |
2312 | 2253 | | |
2313 | 2254 | | |
2314 | 2255 | | |
| |||
2329 | 2270 | | |
2330 | 2271 | | |
2331 | 2272 | | |
2332 | | - | |
2333 | | - | |
2334 | | - | |
2335 | | - | |
2336 | | - | |
2337 | | - | |
2338 | | - | |
2339 | | - | |
2340 | | - | |
2341 | | - | |
2342 | | - | |
2343 | | - | |
2344 | | - | |
2345 | | - | |
2346 | 2273 | | |
2347 | 2274 | | |
2348 | 2275 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
24 | 24 | | |
25 | 25 | | |
26 | 26 | | |
27 | | - | |
28 | | - | |
29 | 27 | | |
30 | 28 | | |
31 | 29 | | |
| |||
51 | 49 | | |
52 | 50 | | |
53 | 51 | | |
54 | | - | |
55 | | - | |
| 52 | + | |
| 53 | + | |
56 | 54 | | |
57 | 55 | | |
58 | 56 | | |
| |||
3750 | 3748 | | |
3751 | 3749 | | |
3752 | 3750 | | |
3753 | | - | |
| 3751 | + | |
3754 | 3752 | | |
3755 | 3753 | | |
3756 | 3754 | | |
| |||
3768 | 3766 | | |
3769 | 3767 | | |
3770 | 3768 | | |
3771 | | - | |
| 3769 | + | |
| 3770 | + | |
| 3771 | + | |
| 3772 | + | |
| 3773 | + | |
| 3774 | + | |
| 3775 | + | |
| 3776 | + | |
| 3777 | + | |
| 3778 | + | |
| 3779 | + | |
| 3780 | + | |
| 3781 | + | |
| 3782 | + | |
| 3783 | + | |
| 3784 | + | |
| 3785 | + | |
| 3786 | + | |
| 3787 | + | |
| 3788 | + | |
| 3789 | + | |
| 3790 | + | |
| 3791 | + | |
| 3792 | + | |
| 3793 | + | |
| 3794 | + | |
| 3795 | + | |
| 3796 | + | |
| 3797 | + | |
| 3798 | + | |
| 3799 | + | |
| 3800 | + | |
| 3801 | + | |
| 3802 | + | |
| 3803 | + | |
| 3804 | + | |
| 3805 | + | |
| 3806 | + | |
| 3807 | + | |
| 3808 | + | |
| 3809 | + | |
| 3810 | + | |
| 3811 | + | |
| 3812 | + | |
3772 | 3813 | | |
3773 | 3814 | | |
3774 | 3815 | | |
3775 | 3816 | | |
| 3817 | + | |
3776 | 3818 | | |
3777 | 3819 | | |
3778 | 3820 | | |
| |||
3872 | 3914 | | |
3873 | 3915 | | |
3874 | 3916 | | |
3875 | | - | |
| 3917 | + | |
3876 | 3918 | | |
3877 | 3919 | | |
3878 | 3920 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
16 | | - | |
17 | | - | |
18 | | - | |
| 16 | + | |
19 | 17 | | |
20 | 18 | | |
21 | 19 | | |
| |||
247 | 245 | | |
248 | 246 | | |
249 | 247 | | |
| 248 | + | |
250 | 249 | | |
251 | | - | |
252 | | - | |
253 | | - | |
254 | | - | |
255 | 250 | | |
256 | 251 | | |
257 | 252 | | |
| |||
339 | 334 | | |
340 | 335 | | |
341 | 336 | | |
342 | | - | |
343 | | - | |
344 | | - | |
345 | | - | |
| 337 | + | |
346 | 338 | | |
347 | 339 | | |
348 | 340 | | |
| |||
0 commit comments