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.
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
- Code reusability — It uses one code based that is shared between both platforms.
axios, Redux, and other libraries that don’t require the DOM from the web.
- Optimized for developer productivity — Comes with features like hot/live module reloading and chrome developer tools for debugging out of the box!
- Performance — Performs better than hybrid application frameworks like Ionic and Cordova since it is not using web views.
- Corporate backing — Lots of companies support and contribute to React Native including Walmart, Airbnb, Wix, and, of course, Facebook.
- 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.
- 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.
- Create React Native App- Similar to Create React App, it gets up and running using the terminal.
- 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.