This browser is no longer supported.

Upgrade to Microsoft Edge to take advantage of the latest features, security updates, and technical support.

Download Microsoft Edge More info about Internet Explorer and Microsoft Edge

If you're brand new to using React, this guide will help you to get started with some basics.

  • A few basic terms and concepts
  • Try using React in Visual Studio Code
  • Try using React with an API
  • Prerequisites

  • Install React ( Should I install on Windows or Windows Subsystem for Linux )
  • Install React on Windows
  • Install React on Windows Subsystem for Linux
  • Install VS Code . We recommend installing VS Code on Windows, regardless of whether you plan to use React on Windows or WSL.
  • A few basic terms and concepts

    React is a JavaScript library for building user interfaces.

  • It is open-source , meaning that you can contribute to it by filing issues or pull requests. (Just like these docs !)

  • It is declarative , meaning that you write the code that you want and React takes that declared code and performs all of the JavaScript/DOM steps to get the desired result.

  • It is component-based , meaning that applications are created using prefabricated and reusable independent code modules that manage their own state and can be glued together using the React framework, making it possible to pass data through your app while keeping state out of the DOM.

  • The React motto is "Learn once, write anywhere." The intention is for code reuse and not making assumptions about how you will use React UI with other technologies, but to make components reusable without the need to rewrite existing code.

  • JSX is a syntax extension for JavaScript written to be used with React that looks like HTML, but is actually a JavaScript file that needs to be compiled, or translated into regular JavaScript.

  • Virtual DOM : DOM stands for Document Object Model and represents the UI of your app. Every time the state of your app's UI changes, the DOM gets updated to represent the change. When a DOM is frequently updating, performance becomes slow. A Virtual DOM is only a visual representation of the DOM, so when the state of the app changes, the virtual DOM is updated rather than the real DOM, reducing the performance cost. It's a representation of a DOM object, like a lightweight copy.

  • Views : are what the user sees rendered in the browser. In React, view is related to the concept of rendering elements that you want a user to see on their screen.

  • State : refers to the data stored by different views. The state will typically rely on who the user is and what the user is doing. For example, signing into a website may show your user profile (view) with your name (state). The state data will change based on the user, but the view will remain the same.

    Try using React in Visual Studio Code

    There are many ways to create an application with React (see the React Overview for examples). This tutorial will walk through how to use create-react-app to fast-forward the set up for a functioning React app so that you can see it running and focus on experimenting with the code, not yet concerning yourself with the build tools.

  • Use create-react-app on Windows or WSL (see the prerequisites above ) to create a new project: npx create-react-app hello-world

  • Change directories so that you're inside the folder for your new app: cd hello-world and start your app: npm start

    Your new React Hello World app will compile and open your default web browser to show that it's running on localhost:3000.

  • Stop running your React app (Ctrl+c) and open it's code files in VS Code by entering: code .

  • Find the src/App.js file and find the header section that reads:

    <p>Edit <code>src/App.js</code> and save to reload.</p>
    

    Change it to read:

    <p>Hello World! This is my first React app.</p>
    

    Try using React with an API

    Using the same Hello World! app that you built with React and updated with Visual Studio Code, let's try adding an API call to display some data.

  • First, let's remove everything from that app.js file and make it into a class component. We will first import component from React and use it to create the class component. (There are two types of components: class and function). We will also add some custom JSX code in a return() statement. You can reload the page to see the result.

    Your app.js file should now look like this:

    import React, { Component } from 'react';
    class App extends Component {
      render() {
        return (
          <p>Hello world! This is my first React app.</p>
    export default App;
    
  • Next, let's set a local state where we can save data from an API. A state object is where we can store data to be used in the view. The view is rendered to the page inside of render().

    To add a local state, we need to first add a constructor. When implementing the constructor for a React.Component subclass, you should call super(props) before any other statement. Otherwise, this.props will be undefined in the constructor, which can lead to bugs. Props are what pass data down into components.

    We also need to initialize the local state and assign an object to this.state. We will use "posts" as an empty array that we can fill with post data from an API.

    Your app.js file should now look like this:

    import React, { Component } from 'react';
    class App extends Component {
    constructor(props) {
        super(props);
        this.state = {
          posts: []
      render() {
        return (
          <p>Hello world!</p>
    export default App;
    
  • To call an API with data for us to use in our React app, we will use the .fetch JavaScript method. The API we will call is JSONPlaceholder, a free API for testing and prototyping that serves up fake placeholder data in JSON format. The componentDidMount method is used to mount the fetch to our React component. The data from the API is saved in our state (using the setState request).

    import React, { Component } from 'react';
    class App extends Component {
    constructor(props) {
        super(props);
        this.state = {
          posts: []
      componentDidMount() {
        const url = "https://jsonplaceholder.typicode.com/albums/1/photos";
        fetch(url)
        .then(response => response.json())
        .then(json => this.setState({ posts: json }))
      render() {
        return (
          <p>Hello world!</p>
    export default App;
    
  • Let's take a look at what sort of data the API has saved in our posts state. Below is some of the contents of the fake JSON API file. We can see the format the data is listed in, using the categories: "albumId", "id", "title", "url", and "thumbnailUrl".

    "albumId": 1, "id": 1, "title": "accusamus beatae ad facilis cum similique qui sunt", "url": "https://via.placeholder.com/600/92c952", "thumbnailUrl": "https://via.placeholder.com/150/92c952" "albumId": 1, "id": 2, "title": "reprehenderit est deserunt velit ipsam", "url": "https://via.placeholder.com/600/771796", "thumbnailUrl": "https://via.placeholder.com/150/771796"
  • We will need to add some page styling to display our API data. Let's just use Bootstrap to handle the styling for us. We can copy + paste the Bootstrap CDN stylesheet reference inside the ./public/index.html file of our React app.

        <!-- Bootstrap -->
        <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.0-beta3/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-eOJMYsd53ii+scO/bJGFsiCZc+5NDVN2yr8+0RDqr0Ql0h+rP48ckxlpbzKgwra6" crossorigin="anonymous">
        <title>React App</title>
      </head>
    
  • To display the API data, referencing our Bootstrap classes for styling, we will now need to add a bit of JSX code inside the rendered return() statement. We will add a container, a header ("Posts from our API call"), and a card for each piece of data from our API. We will use the map() method to display our data from the posts object that we stored it in as keys. Each card will display a header with "ID #" and then the post.id key value + post.title key value from our JSON data. Followed by the body displaying the image based on the thumbnailURL key value.

      render() {
        const { posts } = this.state;
        return (
          <div className="container">
            <div class="jumbotron">
              <h1 class="display-4">Posts from our API call</h1>
            {posts.map((post) => (
              <div className="card" key={post.id}>
                <div className="card-header">
                  ID #{post.id} {post.title}
                <div className="card-body">
                  <img src={post.thumbnailUrl}></img>
    
  • Run your React app again: npm start and take a look in your local web browser on localhost:3000 to see your API data being displayed.

    Additional resources

  • The official React docs offer all of the latest, up-to-date information on React
  • Microsoft Edge Add-ons for React Developer Tools: Add two tabs to your Microsoft Edge dev tools to help with your React development: Components and Profiler.
  • The React learning path contains online course modules to help you get started with the basics.
  •