2017-11-06 13:02:18 -05:00
# The Application Shell
2018-10-11 14:37:30 -04:00
You begin by creating an initial application using the Angular CLI. Throughout this tutorial, you’ ll modify and extend that starter application to create the Tour of Heroes app.
2017-11-06 13:02:18 -05:00
2018-10-11 14:37:30 -04:00
In this part of the tutorial, you'll do the following:
2017-11-06 13:02:18 -05:00
2018-10-11 14:37:30 -04:00
1. Set up your environment.
2. Create a new workspace and initial app project.
3. Serve the application.
4. Make changes to the application.
2017-11-06 13:02:18 -05:00
2018-10-11 14:37:30 -04:00
## Set up your environment
2017-11-06 13:02:18 -05:00
2018-10-11 14:37:30 -04:00
To set up your development environment, follow these instructions in [Getting Started ](guide/quickstart ):
2017-11-06 13:02:18 -05:00
2018-10-11 14:37:30 -04:00
* [Prerequisites ](guide/quickstart#prerequisites )
* [Install the Angular CLI ](guide/quickstart#install-cli )
2018-03-30 17:02:03 -04:00
2018-07-19 18:00:08 -04:00
< div class = "alert is-helpful" >
2018-03-30 17:02:03 -04:00
2018-10-11 14:37:30 -04:00
**Note:**: You do not need to complete the entire Getting Started. After you complete the above two sections of Getting Started, your environment is set up. Continue below to create the Tour of Heroes workspace and an initial app project.
< / div >
2018-03-30 17:02:03 -04:00
2018-10-11 14:37:30 -04:00
## Create a new workspace and an initial application
2018-03-30 17:02:03 -04:00
2018-10-11 14:37:30 -04:00
You develop apps in the context of an Angular [workspace ](guide/glossary#workspace ). A workspace contains the files for one or more [projects ](guide/glossary#project ). A project is the set of files that comprise an app, a library, or end-to-end (e2e) tests. For this tutorial, you will create a new workspace.
2018-03-30 17:02:03 -04:00
2018-10-11 14:37:30 -04:00
To create a new workspace and an initial app project:
1. Ensure that you are not already in an Angular workspace folder. For example, if you have previously created the Getting Started workspace, change to the parent of that folder.
2. Run the CLI command `ng new` and provide the name `angular-tour-of-heroes` , as shown here:
2018-03-30 17:02:03 -04:00
2018-10-11 14:37:30 -04:00
< code-example language = "sh" class = "code-shell" >
ng new angular-tour-of-heroes
< / code-example >
3. The `ng new` command prompts you for information about features to include in the initial app project. Accept the defaults by pressing the Enter or Return key.
The Angular CLI installs the necessary Angular `npm` packages and other dependencies. This can take a few minutes.
It also creates the following workspace and starter project files:
* A new workspace, with a root folder named `angular-tour-of-heroes` .
* An initial skeleton app project, also called `angular-tour-of-heroes` (in the `src` subfolder).
* An end-to-end test project (in the e2e subfolder).
* Related configuration files.
The initial app project contains a simple Welcome app, ready to run.
2018-03-30 17:02:03 -04:00
2017-11-06 13:02:18 -05:00
## Serve the application
2018-10-11 14:37:30 -04:00
Go to the workspace directory and launch the application.
2017-11-06 13:02:18 -05:00
< code-example language = "sh" class = "code-shell" >
cd angular-tour-of-heroes
ng serve --open
< / code-example >
2018-10-11 14:37:30 -04:00
2018-07-19 18:00:08 -04:00
< div class = "alert is-helpful" >
2017-11-06 13:02:18 -05:00
The `ng serve` command builds the app, starts the development server,
watches the source files, and rebuilds the app as you make changes to those files.
The `--open` flag opens a browser to `http://localhost:4200/` .
< / div >
You should see the app running in your browser.
## Angular components
The page you see is the _application shell_ .
The shell is controlled by an Angular **component** named `AppComponent` .
_Components_ are the fundamental building blocks of Angular applications.
They display data on the screen, listen for user input, and take action based on that input.
2018-10-11 14:37:30 -04:00
## Make changes to the application
2017-11-06 13:02:18 -05:00
2018-10-11 14:37:30 -04:00
Open the project in your favorite editor or IDE and navigate to the `src/app` folder to make some changes to the starter app.
2017-11-06 13:02:18 -05:00
You'll find the implementation of the shell `AppComponent` distributed over three files:
2018-10-11 14:37:30 -04:00
1. `app.component.ts` — the component class code, written in TypeScript.
2017-11-06 13:02:18 -05:00
1. `app.component.html` — the component template, written in HTML.
1. `app.component.css` — the component's private CSS styles.
2018-10-11 14:37:30 -04:00
### Change the application title
2017-11-06 13:02:18 -05:00
Open the component class file (`app.component.ts`) and change the value of the `title` property to 'Tour of Heroes'.
< code-example path = "toh-pt0/src/app/app.component.ts" region = "set-title" title = "app.component.ts (class title property)" linenums = "false" >
< / code-example >
2017-11-09 18:37:36 -05:00
Open the component template file (`app.component.html`) and
2017-11-06 13:02:18 -05:00
delete the default template generated by the Angular CLI.
Replace it with the following line of HTML.
2018-10-11 14:37:30 -04:00
< code-example path = "toh-pt0/src/app/app.component.html"
2017-11-06 13:02:18 -05:00
title="app.component.html (template)" linenums="false">
< / code-example >
2018-10-11 14:37:30 -04:00
The double curly braces are Angular's *interpolation binding* syntax.
This interpolation binding presents the component's `title` property value
2017-11-06 13:02:18 -05:00
inside the HTML header tag.
The browser refreshes and displays the new application title.
{@a app-wide-styles}
2018-10-11 14:37:30 -04:00
### Add application styles
2017-11-06 13:02:18 -05:00
Most apps strive for a consistent look across the application.
The CLI generated an empty `styles.css` for this purpose.
Put your application-wide styles there.
Here's an excerpt from the `styles.css` for the _Tour of Heroes_ sample app.
< code-example path = "toh-pt0/src/styles.1.css" title = "src/styles.css (excerpt)" >
< / code-example >
## Final code review
2018-10-11 14:37:30 -04:00
The source code for this tutorial and the complete _Tour of Heroes_ global styles
are available in the < live-example > < / live-example > .
2017-11-06 13:02:18 -05:00
2018-10-11 14:37:30 -04:00
Here are the code files discussed on this page.
2017-11-06 13:02:18 -05:00
< code-tabs >
< code-pane title = "src/app/app.component.ts" path = "toh-pt0/src/app/app.component.ts" >
< / code-pane >
< code-pane title = "src/app/app.component.html" path = "toh-pt0/src/app/app.component.html" >
< / code-pane >
2018-10-11 14:37:30 -04:00
< code-pane
title="src/styles.css (excerpt)"
2017-11-06 13:02:18 -05:00
path="toh-pt0/src/styles.1.css">
< / code-pane >
< / code-tabs >
## Summary
* You created the initial application structure using the Angular CLI.
* You learned that Angular components display data.
2018-10-11 14:37:30 -04:00
* You used the double curly braces of interpolation to display the app title.