React Native uruchamia kod JavaScript i natywny, które muszą się komunikować. Oryginalna architektura używała asynchronicznego bridge; nowa architektura (JSI, TurboModules, Fabric) umożliwia szybszą, synchroniczną komunikację. Zrozumienie tego wyjaśnia zachowanie i wydajność React Native.
Oryginalna architektura: bridge
React Native runs:
→ a JS THREAD (your React/JS code) and the NATIVE side (UI, native modules)
→ they communicate over a BRIDGE: messages are SERIALIZED (to JSON), passed ASYNC,
and deserialized on the other side
Limitations:
✗ ASYNCHRONOUS only (can't call native synchronously)
✗ SERIALIZATION overhead; the bridge can be a BOTTLENECK with heavy traffic
✗ e.g. fast scrolling/animations passing data over the bridge → jank
