React Native
Developing a Mobile App with Expo
React Native is a convenient JavaScript framework created by Meta Platforms Inc. for developing applications. Specifically, its ability to natively render mobile applications on both iOS and Andriod platforms. In addition to its cross-platform functionality, it is primarily based off of React, allowing programmers to immigrate to this framework at ease. Furthermore, React Native is an open-source framework that consists of numerous libraries to assist your application development.
Before my CSC301 advanture, I had no basics in React nor React Native. However, React Native is not a tough framework to learn, so don’t stress out and feel free to dive into the basic documentations and beginner courses! Many interactive examples are provided by the developers for you to test and play around with.
Meanwhile, EXPO is a open-source platform built around React Native. It contains a series of useful tools for developing a React Native app. This includes convenient commands to create and test your app universally on iOS, Android and web without additional configuration. The Expo developers has also offered a well-designed starter guide, which is how I started the CSC301 project. Hence, it is highly recommended to use Expo if you are beginning the development of a mobile app. Furthermore, even existing React Native apps can have the expo
package installed.
With Expo’s EAS Update and EAS Build features, development builds can be launched instantly, and your app can be tested on mobile devices or mobile device simulators. Official builds can also be launched efficiently to share among your team, or even make its way to AppStore and Google Play. Additionally, Expo offers a web dashboard with concise UI that aids the management of projects and their deployment. You can sign up for a free Expo account and manage your projects on this dashboard. The Expo-CLI is the command-line tool that connects all these tools together, and even helps to securely manage your project’s dependencies.
- Set up
- Installation
- Install Node.js and npm (Node Package Manager) on your computer. You can download and install Node.js from the [official website(https://nodejs.org/en/):
#Note: Suggested to download the LTS version (or even numbered versions npm) because it is generally more stable. Use
npm -v
andNode -v
to check your installed version. - Install Expo Go on your iOS device or Android device via App Store and Google Play Store
- Download VS Code Extensions
- ES7+ React/Redux/React-Native snippets (Extension ID: dsznajder.es7-react-js-snippets)
- React Native Tools (Extension ID: msjsdiag.vscode-react-native)
- Install Node.js and npm (Node Package Manager) on your computer. You can download and install Node.js from the [official website(https://nodejs.org/en/):
#Note: Suggested to download the LTS version (or even numbered versions npm) because it is generally more stable. Use
- Command
- Initialize your Expo App
npx create-expo-app <your_app_name>
- Global Expo CLI (command line tool) is already deprecated. So all our commands will now be using the new Expo CLI which is bundled in the
expo
package at the initiation of your project. Hence, no command line tool is needed to be installed. To use the new Expo CLI, use:npx expo <command>
andnpx expo --help
to view all possible commands - Start Expo Development server
cd <your_app_name>
npx expo start
- Installing Dependencies
npx expo install <library-name>
ornpx expo install
to install libraries to local repository specified inpackage.json
- Useful dependencies:
react-native-web
and@expo/webpack-config
– to run your development on a web browserjest
andjest-expo
– Useful react Native testing packages. Extra configurations need to be made in your project, for more details see Expo Unit Testing Documentation and guidereact-navigation
– Handy library to manage navigation between different screens in your appaxios
– A great library to make HTTP requests for connecting your front-end to a back-end server
- Useful dependencies:
- Initialize your Expo App
- Running expo
- Phone
Scan the QR Code from running the “
npx expo start
” command. For iOS device, scan using your phone’s default camera and it will automatically redirect you to the Expo Go App, and Android devices can scan the QR code using the Expo Go app. #Note: you can shake your phone or put three fingers on the screen to restart the app without closing the app and reopening it. - Emulator on PC
- macOS You can try to use Xcode on your mac device and see live changes without using a mobile device
- Windows You can run an ios emulator or android emulator using the React Native Tools installed earlier
- With the relative dependencies installed, press ‘w’ to open a web browser to view your development build
- Press ‘j’ to open a debugger. Here is a detailed guide on how to debug your application
- Phone
Scan the QR Code from running the “
- Installation
- Common React Native Components
This guide provides an overview of commonly-used React Native components for mobile app development. - Managing Dependencies
As your project grows, your list of dependencies will inevitably grow. To ensure a tidy workspace for you and everyone on the team, it is a good practise to keep a clean dependency list and locally installed libraries. In any React Native App, there is a
package.json
file that keeps a list of the required dependencies (and their version), and apackage-lock.json
file that ensures installations by locking the exact versions of dependencies. These two files are crucial must be in-sync for the team, so make sure always have the correct version of it on everyone’s branch, and remove redundant dependencies. Therefore, I suggest having a specific branch to manage the dependencies to make sure everyone on the team are using the same versions of each library, and to avoid conflicts. Meanwhile, the locally installed libraries are in thenode_modules
directory, and does not need to be committed unless for special needs. All team members updating their local repository should simply runnpx expo install
when theirpackage.json
is up-to-date. FYI,node_modules
and.expo
directories are automatically in.gitignore
if you created the project using Expo.