James Yoo

Deploying React SPA in 10 Minutes using Azure

11 March 2020 — Written by James
#azure#react#cloud#programming

In this article, I would like to show how to deploy a React single page application within a short time. Microsoft is providing developers and engineers with great user experience, so I think sharing this article would help you to start your journey of cloud service at Azure.



Prerequisites


create-react-app

Let's open Terminal, and run the following to create a React app

npx create-react-app myreactapp
cd myreactapp
npm start

The use of create-react-app might be controversial as it also installs several packages and modules that you would not use, but I would use it anyway for simplicity.

Once you run the above command and do npm start, you would see the below as usual. React default landing page


react-router / react-router-dom

To create a Single Page Application (SPA) in this writing, I use React Router for this tutorial. While we interact with a server and load the entire new page in an old way, a SPA retrieves relevant codes with a single page load or/and update codes when necessary. For example, when a user enters input and hits a button, only part of the website changes due to his / her action.

Anyway, let's install React Router and proceed. In the Terminal, run

npm install --save react-router-dom

In this tutorial, I make 3 different simple components, Main, About and Contact.

Main.js

import react from 'react';

function Main() {

    return (
        <h1>Main</h1>
    )
}

export default Main;

About.js

import react from "react";

function About() {
  return <h2>About</h2>;
}

export default About;

Contact.js

import react from "react";

function Contact() {
  return <h3>Contact</h3>;
}

export default Contact;

Visual Studio Code

Before deploying a website, install Azure extension on VS Code. Azure extension list

After signing in Azure, and create a storage account by right-clicking the Free Trial (it would be different depending on you account type) Create storage account

You will be asked your app name. Also, if you do not have any Resource Group in Azure, it will ask the name of Resource Group as well. By default, your storage account will be created in US West, but you can also choose the region by clicking "Create Storage Account... (Advanced)" as shown above.

The very last step in this section is to configure your storage account. Once you created your storage account, you would see the following icon. My react app

Once you click "Configure Static Website..." you will be asked to choose the file name of index page and error (404) pages. Type index.html for both of them, and finish the configuration.


Deployment

We are almost done! Once you finish the above steps, we now need to build and deploy the app so that people can see.

On Terminal (at the root of the app), enter the following so that build" folder is created and ready to be deployed.

npm run build

Finally, open the VS Code again, and right-click the "build" folder. Choose "Deploy to Static Website...", and wait for a minute.

Deploy to static website

James Yoo