Getting Started with React: An Introduction
Getting Started with React: An Introduction

Getting Started with React: An Introduction

In this comprehensive guide, we will take our first steps into the world of React. We’ll delve into React’s background, explore its versatile use cases, set up a basic React development environment on your local computer, and create a simple starter app. Along the way, you’ll gain insights into how React operates and its core principles.

React: More than Just a Library

React is a powerful JavaScript library designed for building user interfaces. It’s important to note that React isn’t a framework in the traditional sense—it transcends the boundaries of web development and can be used in conjunction with other libraries to render in diverse environments. For example, React Native leverages React to develop mobile applications.

To build web applications, developers commonly pair React with ReactDOM. React and ReactDOM are often mentioned alongside true web development frameworks, which has led to colloquial usage referring to React as a “framework.” In this article, we will adopt this common terminology for ease of understanding.

The Core Purpose of React

React’s primary mission is to reduce the occurrence of bugs while crafting user interfaces. It accomplishes this through the use of components—self-contained, logical code segments that define specific portions of the user interface. These components can be combined to construct a complete user interface, abstracting much of the rendering complexity and allowing developers to focus on UI design.

Diverse Use Cases

Unlike some other frameworks, React doesn’t impose strict rules on code conventions or file organization. This flexibility empowers development teams to establish conventions that best suit their needs and adopt React in a manner that aligns with their project’s requirements. React can be employed to handle a single button, a few UI elements, or an entire application’s user interface.

While React can certainly be used for small UI components, its true potential shines when you build your entire application using React. It’s not as straightforward to integrate React incrementally into an existing project compared to libraries like jQuery or frameworks like Vue. React often requires a compilation process, which can introduce some complexity to your development workflow.

Embracing JSX for Declarative UI

React leverages modern JavaScript features extensively. One of the most notable departures from traditional JavaScript is the use of JSX syntax. JSX extends JavaScript’s syntax to accommodate HTML-like code alongside it. For instance:

const heading = <h1>Mozilla Developer Network</h1>;

This heading constant represents a JSX expression that React can use to render an <h1> tag within our app. JSX facilitates nesting elements just like HTML:

const header = (
<h1>Mozilla Developer Network</h1>


Although it’s possible to bypass the compilation step and use React.createElement() to craft UI elements manually, doing so forfeits the declarative advantages of JSX, making the code less readable. Most front-end development workflows already involve a build process, so configuring JSX compilation is often straightforward. JSX’s blend of HTML and JavaScript may initially appear daunting, but once you’re accustomed to it, it enables faster and more intuitive UI development.

Setting Up Your First React Application

While there are various ways to work with React, we will focus on using the command-line interface (CLI) tool called create-react-app. This tool streamlines the development process by handling package installations, file creation, and tooling setup.


Before you dive into React with create-react-app, ensure you have Node.js installed, preferably the long-term support (LTS) version. Node.js includes npm (Node Package Manager) and npx (Node Package Runner), which are crucial for our development.

If you prefer Yarn as a package manager, it’s a viable alternative. However, for the purpose of this tutorial, we’ll assume you are using npm. You can learn more about npm and Yarn in the “Package Management Basics” section.

On Windows, you may need additional software to mimic Unix/macOS terminal functionality for executing the terminal commands mentioned in this tutorial. Tools like Gitbash (part of the git for Windows toolset) or Windows Subsystem for Linux (WSL) are suitable options. Refer to the “Command Line Crash Course” for more insights into these tools and terminal commands.

Moreover, keep in mind that React and ReactDOM are best suited for modern browsers (e.g., Firefox, Microsoft Edge, Safari, or Chrome). These libraries may require polyfills to work with older browsers like IE9+. Using a modern browser will ensure a smooth learning experience.

Initializing Your React App

To kickstart your React journey, use the create-react-app CLI with the desired app name. This command not only creates a new directory but also installs essential npm packages, generates scripts for running your application, and establishes the basic project structure. If you have Git installed, it even initializes the directory as a Git repository.

Execute the following command in your terminal after navigating to your preferred project location:

npx create-react-app moz-todo-react

This command will create a moz-todo-react directory and handle the necessary setup tasks for you.


We’ve reached the end of our initial exploration of React, covering local installation, app setup, and fundamental concepts. In the upcoming article, we will delve deeper into React’s capabilities by building a practical application—a to-do list. But before we proceed, let’s recap some essential takeaways:

In React:

  • Components can import necessary modules and should be exported at the bottom of their files.
  • Component functions should follow PascalCase naming conventions.
  • JSX variables are enclosed in curly braces, like {so}.
  • Some JSX attributes differ from HTML attributes to avoid conflicts with reserved JavaScript keywords. For example, class in HTML becomes className in JSX, and multi-word attributes follow camelCase.

Stay tuned for the next installment, where we will embark on the exciting journey of building a React-powered to-do list application!

Software Engineer
Post On September 27, 2023 | By Paul Johnson

Working Remotely As A Software Engineer- A Guide For 2023

The Comprehensive Guide to Remote Work for Software Engineers Introduction: Working remotely as a Software Engineer has become an increasingly attractive option in recent years. This paradigm shift not only saves time and money on commuting but also allows for greater work-life balance and the freedom to choose your own work environment. In this comprehensiveRead more

Remote Web Developer
Post On September 27, 2023 | By Paul Johnson

Remote Web Developer: the Advantages of Working with this Professional

Unlocking the Potential of Remote Web Developers for Your Business Subtitle 1: The Rise of Remote Work in the Digital Age In recent years, the concept of remote work has experienced exponential growth, primarily fueled by the proliferation of digital professions and a transformative shift in corporate mindset. Subtitle 2: Exploring the Benefits of CollaboratingRead more

Remote Web Developer vs Freelance Web Developer
Post On September 27, 2023 | By Paul Johnson

Remote Web Developer vs Freelance Web Developer: Pros and Cons

Choosing Between Freelance Web Developers and Full-time Remote Developers: Pros and Cons Introduction In the wake of the significant shift towards remote work and the growing importance of user-friendly interfaces, businesses face a crucial decision when seeking skilled web developers. The question that arises is whether to hire a freelancer or a full-time remote webRead more

Brands we WORK with

2013 - 2023 Foreignerds Inc. All Rights Reserved