React Native

React Native is a cross-platform framework for building mobile applications that can run outside of the browser — most commonly iOS and Android applications

It can be used to build applications on Windows devices, desktop OS’s, and Apple TV apps as well but this guide will only be covering its most common purpose — Android and iOS applications.

Table of Contents

What is React Native?

React Native falls in-between native and hybrid applications on the mobile app spectrum. The user interface you create is entirely native and the overall application performance is nearly as good as writing a native app.

It also gives you the flexibility to embed web views (webpages) or native code (Java/Kotlin for Android, Objective C/Swift for iOS) inside your applications wherever you want.

It follows the same pattern as React where the views (what you see on the screen) are rendered from the JavaScript files. The difference is that it supplies its own API for handling native mobile views vs the DOM on the web.

If you are confused about how this works, follow this guide on freeCodeCamp and it will take you step by step through these concepts.

Reasons to choose React Native

  1. Code reusability — It uses one code based that is shared between both platforms.
  2. Reuse web tools and skills — Reuse JavaScript knowledge, tools and utilities like axios, Redux, and other libraries that don’t require the DOM from the web.
  3. Optimized for developer productivity — Comes with features like hot/live module reloading and chrome developer tools for debugging out of the box!
  4. Performance — Performs better than hybrid application frameworks like Ionic and Cordova since it is not using web views.
  5. Corporate backing — Lots of companies support and contribute to React Native including Walmart, Airbnb, Wix, and, of course, Facebook.
  6. Community — React Native has a large (and growing) community with over 1500 contributors to the core project and thousands more who contribute to various libraries.
  7. Better user experience — React Native uses the JavaScript code to render native components from your phone’s OS. In other words, the application’s user interface (UI) is entirely native!
  8. Cross-Platform - Great way to prototype and save time while building either a universal user interface or platform specific mobile application that can run on both iOS and Android devices.

How to Get Started with React Native

There are two quick easy ways to get started with React Native. Depending on your situation, one can be a better option for you.

  1. Create React Native App- Similar to Create React App, it gets up and running using the terminal.
  2. Expo - Best for prototyping an app or if it is earlier stage. Using Expo you can even create a quick app using drag and drop features from snack.expo.io in the browser.

More resources on React Native: