In this post we re going to cover how to get a Angular 2 application up and running and then deploy it to Firebase. First lets cover how to use the Angular CLI to help bootstrap our application’s build process.

Angular 2 CLI

The Angular 2 CLI is an officially supported project by the Angular team. You can find more information at First we will install the Angular CLI tool. To install we install via NPM running the following command: npm install angular-cli -g. This will install the CLI globally to our machine to help us create new Angular projects.

Once installed we can create a new Angular 2 app by running the following command: ng new my-cool-app. Next open your app in your favorite editor and you should see something similar to this (as of CLI beta 10):

New Angular 2 CLI project Structure

Starting the CLI

Now runing a command prompt at the root of our project we can run the following command: ng serve. This will build our project and start a live reload server for development. So if we browse to localhost:4200 we should see the following:

Running Angular 2 CLI app

Build for Production

I wont cover all the CLI commands in this post. I recommend checking out the CLI Docs. We will just start with running ng build --prod. This command runs a build for our project but with additional production optimizations such as bundling and minification. Now your project should have a dist/ directory. This is where all of our compiled ready to deploy code is located every time we run a build.

Firebase CLI

So now that we have learned how to use the Angular 2 CLI to package up our app for deployment we will use the Firebase CLI to create a live hosting project to deploy to.

First you will want to log into Firebase and go to Once in the console select “Create New Project”. For our project we will name it “my-cool-app”.

Creating a Firebase Project

Now that we have a project created lets go back to the command line. Next we next install the Firebase CLI via NPM. In your console run the following command: npm install -g firebase-tools. Once installed run firebase login to login to your Firebase account.

Deployment Setup

Now that Firebase CLI is installed, at the root of your Angular CLI project run firebase init. This will walk through the steps of setting up your app to be deployable to Firebase Hosting.

Creating a Firebase Hosting Project

Select the Hosting option in the command line. Next select our project my-cool-app that we created earlier. Next it will ask what file to use for the Firebase real time database rules. For now you can just use the default.

The next step is important! The cli will ask what folder to use as the public directory. For our project we want to use the dist/ directory instead of Firebase’s default public/ directory. So type in the command line dist.

Next it will ask if this is a single page app and if it should rewrite all urls to index.html. For our app select yes. If it asks to over write the index.html file select no. Now your app is ready for deployment! In the root of your app you should have a new file firebase.json file that helps the Firebase CLI know how to deploy our application. Now run firebase deploy. Firebase will provide domain that you can configure to a custom domain in the console. Now if we open our browser we will see something similar to the following:

Live Angular 2 Firebase project

Now that we have created an Angular 2 project and deployed it to Firebase I recommend digging into more of the Angular 2 CLI and the Firebase Features. A few things to note, the CLI at the time of this writing is in Beta 10. A large change is in the works for Beta 11 to switch the underlying build system to Webpack. This post will be updated with those changes. Also in future versions of the Angular CLI will possibly have Firebase integration and deployment built in. Also as of Beta 10 of the Angular CLI production build do not have a versioning system to bust browser cache. This should be addressed in upcoming versions.