React Native - Installation and Setup
Hey Guys!!
Note : I have downloaded v7.10.1, Because, React native doesn't support the latest v8 yet. (at the time of writing).
Good Day! Basically I am an Android Developer who's doing stuffs in Java/Kotlin. So naturally, I am not curious about hybrid apps because of it lack of look and feel. Until, I have read about React Native somewhere and get to know that is not using webview to render other views like TextView, ListView, etc.
So How it's working?
It uses native components in both IOS and Android depends on its platform. Interesting right? Yeah it is. Definitely, it bridges the lack of look and feel in Cross-platform apps.
Okay. Good. How can I start that?
React Native has its own pretty good documentation. You can to the link, https://facebook.github.io/react-native/docs/getting-started.html and check it out.
Let's Install
Actually, we can install it in two ways:
(i) With Create Native React App - For purely javascript code
(ii) With React Native CLI - For both javascript and native code
(i) With Create Native React App
In this way, we don't need Android Studio or XCode to be installed. You can directly write JavaScript code to support both the platforms. But we can't use any native specific components in this way.
- First, Let's install Nodejs. You can download the package in Node.js site.
Note : I have downloaded v7.10.1, Because, React native doesn't support the latest v8 yet. (at the time of writing).
- Next, we can install WatchMan. As per doc of React Native, its not mandatory to install that. But I found its good to install it, to avoid some errors in future. You can find the package and instructions to install, here.
- Now we can directly install Create React Native App directly in terminal using npm, using the following command.
npm install -g create-react-native-app - Now we are good to create new React Native project. Use the following commands to do so.
create-react-native-app MyProject
- The project has been created now. Now we can navigate to the project location and start exploring it.cd MyProjectnpm start
- Now QR code and an local url will be generated in terminal.
- To run the application on Android or IOS devices, we have to install Expo app in it. Expo is available at both Google playstore and AppStore. Also both your computer and device should use the same wireless network. Using Expo, we can view our React native application's changes live with hot reloading.
(ii) With React Native CLI
This way is very useful to use both Android and IOS features and specific components/codes with the benefit of JavaScript. It requires the installation of Android or IOS, or both. (Depends on your need and familiarity withe the languages.)
- Before starting installation of CLI, we can install Android Studio or XCode and make it ready. You can find instructions, requirements of installation for Android Studio, here and for Xcode, here.
- It requires to install Node and Python2. So now we can proceed with installation of Node.js by downloading it, here. Note : I have downloaded v7.10.1, Because, React native doesn't support the latest v8 yet. (at the time of writing).
- We have to install Python2 from here.
- Next, we can install WatchMan. You can find the package and instructions to install, here.
- Then, Yarn should be installed to fasten up your project creation and setup for CLI. You can download it, here.
- Now we can install CLI with following command in terminal.
npm install -g react-native-cli - Now we can create new project with following command:
react-native init AwesomeProject - Then make your physical device or Emulator ready to run the application. And navigate to project's location and enter the following command.
cd AwesomeProject
react-native run-android (for Android) react-native run-ios (for IOS) - Now you can view the application in device. And you can modify App.js file as your wish. You can install any editor for that. I am using Atom, in case you're curious;) That's it. Installation and setup for React Native was done. In next post, we can explore React Native basics. Until then, Stay Tuned!! Byeee!!!
Comments
Post a Comment