Exploring the Depths of React Native’s New Architecture: Hermes, JSI, Fabric, Yoga, Turbo Module, and Codegen

Sugand singh
4 min readAug 30, 2023

React Native has long been the go-to framework for building cross-platform mobile applications with JavaScript. Its ability to create smooth, performant, and native-like experiences for both iOS and Android has attracted developers worldwide. However, as the mobile landscape evolves, so must the tools we use to build applications. In response to this, React Native has undergone a significant architectural transformation, incorporating various new technologies to enhance its performance, reliability, and developer experience. In this article, we will take an in-depth look at some of these architectural changes: Hermes, JSI (JavaScript Interface), Fabric, Yoga, Turbo Modules, and Codegen

1. Hermes: The JavaScript Engine

One of the most fundamental changes to React Native’s architecture is the adoption of the Hermes JavaScript engine. Hermes aims to improve application startup time, reduce memory usage, and enhance overall JavaScript execution performance. It achieves this by using ahead-of-time (AOT) compilation, which translates JavaScript code into more efficient bytecode before the application even starts running. This leads to faster initialization and less runtime overhead, making your React Native applications snappier and more responsive.

2. JSI (JavaScript Interface)

JSI, short for JavaScript Interface, is a bridge that enables direct communication between native code and JavaScript. Unlike the previous bridge, which involved multiple conversions between JavaScript and native data types, JSI allows for direct interaction. This results in faster data transfers and method calls, further contributing to the overall performance improvement of React Native applications.

3. Fabric: The React Native UI Manager

Fabric is a reimagined and redesigned version of React Native’s UI manager. It’s built with a focus on improving UI responsiveness and performance. Fabric operates on a different threading model, allowing UI updates to be performed more efficiently and with finer granularity. This enables a smoother user experience, as UI interactions are less likely to be blocked by expensive JavaScript computations.

4. Yoga — Layout Engine

Yoga, a cross-platform layout engine, plays a crucial role in determining how UI components are positioned and sized within a React Native application. It ensures consistent layouts across different devices and screen sizes. While not a new addition, Yoga’s integration into the revamped architecture remains pivotal to maintaining a responsive and adaptable user interface.

5. Turbo Modules: Optimized Native Modules

Turbo Modules are an evolution of the native module system in React Native. They aim to enhance the efficiency of native module loading and execution. With Turbo Modules, the initialization of native modules is faster, resulting in improved startup times for your application. This architectural addition helps maintain the seamless integration of native functionality into your React Native app while keeping performance in mind.

6. Codegen — Static Type Checking for Bridge

Codegen is a mechanism that generates static type information for the JavaScript-to-native bridge. This enables better type checking and auto-completion in your IDE, making your development process more robust and error-free. By catching type-related issues during development, Codegen contributes to reducing runtime errors and enhancing the stability of your React Native applications.

Conclusion

React Native’s new architecture, encompassing Hermes, JSI, Fabric, Yoga, Turbo Modules, and Codegen, represents a significant leap forward in terms of performance, reliability, and developer experience. These technologies work in harmony to create a smoother, more efficient development process and deliver more responsive and native-like applications. By diving deep into these architectural changes, you’ll be better equipped to harness the power of React Native and build cutting-edge mobile experiences for your users. So, why wait? Embrace the future of mobile app development with React Native’s new architecture today!

I have tried my best to give you detailed information about how to use custom fonts. Thanks for reading my article. Please clap if you like it!

Sign up to discover human stories that deepen your understanding of the world.

Free

Distraction-free reading. No ads.

Organize your knowledge with lists and highlights.

Tell your story. Find your audience.

Membership

Read member-only stories

Support writers you read most

Earn money for your writing

Listen to audio narrations

Read offline with the Medium app

Sugand singh
Sugand singh

Written by Sugand singh

Experienced React Native dev, UI/UX expert, performance optimizer. Keeping up with mobile trends. Let's build mobile magic!

No responses yet

Write a response