A Beginner's Guide to React Native: Building Cross-Platform Mobile Apps

A Beginner's Guide to React Native: Building Cross-Platform Mobile Apps

If you've ever dreamed of creating mobile apps that work on both Android and iOS without needing two separate codebases, you're in the right place! React Native makes this possible. This guide is your perfect starting point to understand the basics, explore the components, and dive into the world of building user-friendly mobile apps—quickly and efficiently. Whether you're a beginner or transitioning from web development, we'll take you step-by-step on this exciting journey.


React Native is an open-source framework developed by Meta (formerly Facebook) that allows developers to build mobile applications using JavaScript and React. Unlike traditional hybrid apps that rely on WebViews, React Native renders using native components, providing a more authentic user experience.


  • Cross-Platform Development: Write once, deploy on both iOS and Android, saving time and resources.
  • Native Performance: Utilizes native components, ensuring high performance and a smooth user experience.
  • Hot Reloading: Instantly see the results of code changes, enhancing development speed.
  • Strong Community Support: A vast ecosystem of libraries and a supportive developer community.

React Native provides a set of core components that serve as the building blocks for your application. These components map directly to the native UI building blocks of iOS and Android, making them intuitive for web developers to learn.


  • What it does: A container for layout and other UI components, similar to a <div> in web development.
  • When to use: Use View to structure and position other components.

Code Example:

import { View } from 'react-native';

<View style={{ padding: 10, backgroundColor: 'lightblue' }}>
  <Text>Hello from View!</Text>
</View>

Web Comparison: Similar to <div> in HTML, but you style it using the StyleSheet object instead of CSS.


  • What it does: Displays text content.
  • When to use: Use Text to show static or dynamic text.

Code Example:

import { Text } from 'react-native';

<Text style={{ fontSize: 20, color: 'darkblue' }}>Hello, React Native!</Text>

Web Comparison: Comparable to <p> or <span> in HTML.


  • What it does: Renders images.
  • When to use: Use Image to show logos, icons, or pictures.

Code Example:

import { Image } from 'react-native';

<Image
  source={{ uri: 'https://reactnative.dev/img/tiny_logo.png' }}
  style={{ width: 100, height: 100 }}
/>

Web Comparison: Similar to the <img> tag, but styles and properties are slightly different.


  • What it does: Allows user input through the keyboard.
  • When to use: Use TextInput for forms or search fields.

Code Example:

import { TextInput } from 'react-native';

<TextInput
  style={{ borderWidth: 1, borderColor: 'gray', padding: 5 }}
  placeholder="Enter your text"
/>

Web Comparison: Similar to <input type="text"> in HTML.


  • What it does: Provides a scrollable container for other components.
  • When to use: Use ScrollView when the content exceeds the screen height or width.

Code Example:

import { ScrollView, Text } from 'react-native';

<ScrollView>
  <Text style={{ fontSize: 18 }}>Scroll me!</Text>
  {/* Add more content here */}
</ScrollView>

Web Comparison: Similar to using overflow: scroll in CSS, but more robust.


  • What it does: Provides pull-to-refresh functionality for scrollable views.
  • When to use: Use it with ScrollView or FlatList for refreshing data.

Code Example:

import { RefreshControl, ScrollView, Text } from 'react-native';

const App = () => {
  const [refreshing, setRefreshing] = useState(false);

  return (
    <ScrollView
      refreshControl={
        <RefreshControl
          refreshing={refreshing}
          onRefresh={() => {
            setRefreshing(true);
            setTimeout(() => setRefreshing(false), 2000);
          }}
        />
      }
    >
      <Text>Pull down to refresh!</Text>
    </ScrollView>
  );
};

  • What it does: Renders an image as a background for other components.
  • When to use: Use it for cards, sections, or full-page backgrounds.

Code Example:

import { ImageBackground, Text, StyleSheet } from 'react-native';

<ImageBackground
  source={{ uri: 'https://example.com/background.jpg' }}
  style={styles.background}
>
  <Text>Inside Background</Text>
</ImageBackground>

const styles = StyleSheet.create({
  background: { width: '100%', height: 200 },
});

  • What it does: A basic button for handling user interactions.
  • When to use: Use Button for actions like submitting forms or navigation.

Code Example:

import { Button } from 'react-native';

<Button title="Press Me" onPress={() => alert('Button Pressed')} />

  • What it does: A toggle switch for boolean values.
  • When to use: Use Switch for on/off controls like settings.

Code Example:

import { Switch } from 'react-native';

<Switch value={true} onValueChange={(value) => console.log(value)} />

  • What it does: A wrapper with dimming feedback when pressed.
  • When to use: Use it for buttons requiring visual feedback.

Code Example:

import { TouchableHighlight, Text } from 'react-native';

<TouchableHighlight onPress={() => console.log('Pressed!')}>
  <Text>Press Me</Text>
</TouchableHighlight>;

  • What it does: A wrapper with opacity reduction on press.
  • When to use: Use it for subtle visual feedback on buttons.

Code Example:

import { TouchableOpacity, Text } from 'react-native';

<TouchableOpacity onPress={() => console.log('Pressed!')}>
  <Text>Press Me</Text>
</TouchableOpacity>;

  • What it does: Displays content above an enclosing view.
  • When to use: Use Modal for dialogs, popups, or forms.

Code Example:

import { Modal, Text, View, Button } from 'react-native';

<Modal visible={true}>
  <View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}>
    <Text>Hello from Modal!</Text>
    <Button title="Close" onPress={() => console.log('Closed!')} />
  </View>
</Modal>

  • What it does: Manages the appearance of the device’s status bar.
  • When to use: Use it to customize or hide the status bar.

Code Example:

import { StatusBar } from 'react-native';

<StatusBar barStyle="dark-content" backgroundColor="#ffffff" />;

React Native allows you to conditionally render components or styles based on the platform (iOS or Android).

Code Example:

import { Platform, Text } from 'react-native';

<Text>
  {Platform.OS === 'android' ? 'Hello Android!' : 'Hello iOS!'}
</Text>

Ready to dive into React Native? Try the Brain Trainer project! Fork it, clone it, and start building your first app.

Brain Trainer Repository

Learning is fun when you experiment—happy coding! 🚀