include ../../../../_includes/_util-fns .l-main-section :markdown # Tour of Heroes Our grand vision is to build an app to help a staffing agency manage its stable of heroes. Even heroes need to find work. Of course we'll only make a little progress in this tutorial. What we do build will have many of the features we expect to find in a full-blown, data-driven application: acquiring and displaying a list of heroes, editing a selected hero's detail, and navigating among different views of heroic data. The Tour of Heroes covers the core fundamentals of Angular. We’ll use built-in directives to show/hide elements and display lists of hero data. We’ll create a component to display hero details and another to show an array of heroes. We'll use one-way data binding for read-only data. We'll add editable fields to update a model with two-way data binding. We'll bind component method to user events like key strokes and clicks. We’ll learn to select a hero from a master list and edit that hero in the details view. We'll format data with pipes. And we'll use routing to navigate among different views and their components. We’ll learn enough core Angular to get started and gain confidence that Angular can do whatever we need it to do. We'll be covering a lot of ground at an introductory level but we’ll find plenty of links to chapters with greater depth. ## The End Game Let's get a visual idea of where we're going in this tour, beginning with the "Heroes" view and its list of heroes: figure.image-display img(src='/resources/images/devguide/toh/heroes-list-1.png' alt="Output of heroes list app") :markdown Above the list are two links ("Dashboard" and "Heroes"). We click them to navigate between a Dashboard view and this Heroes view. After selecting a hero, we can click the "View Details" button and be wisked away by the router to a "Hero Details" view where we can change the hero's name. figure.image-display img(src='/resources/images/devguide/toh/hero-details-1.png' alt="Details of hero in app") :markdown Links at the top take us back to either of the main views. The "Back" button returns us to the "Heroes" view. ## How We Roll We’ll build this Tour of Heroes together, step by step. We'll motiviate each step with a requirement that we've met in countless applications. Everything has a reason. And we’ll meet many of the core fundamentals of Angular along the way. .l-main-section :markdown # Once Upon a Time Every story starts somewhere. Our story starts where the [QuickStart](../quickstart) ends. Follow the "QuickStart" steps. They provide the prerequisites, the folder structure, and the core files for our Tour of Heroes. Copy the "QuickStart" code to a new folder and rename the folder `angular2-tour-of-heroes`. We should have the following structure: code-example. angular2-tour-of-heroes ├── node_modules ├── src | ├── app | | └── app.ts | ├── index.html | └── tsconfig.json └── package.json :markdown ## Keep the App Running Start the TypeScript compiler and have it watch for changes in one terminal window by typing pre.prettyprint.lang-bash code tsc -p src -w :markdown Now open another terminal window and start the server by typing pre.prettyprint.lang-bash code live-server --open=src :markdown This command starts the server, launches the app in a browser, and keeps the app running while we continue to build the Tour of Heroes. .alert.is-helpful :markdown These two steps watch all project files. They recompile TypeScript files and re-run the app when any file changes. If the watchers fail to detect renamed or new files, stop these commands in each terminal by typing `CTRL+C` and then re-run them. .l-main-section :markdown # Show our Hero We want to display Hero data in our app Let's add two properties to our `AppComponent`, a `title` property for the application name and a `hero` property for a hero named "Windstorm". ``` class AppComponent { public title = 'Tour of Heroes'; public hero = 'Windstorm'; } ``` :markdown Now we update the template in the `@Component` decoration with data bindings to these new properties. code-example(format="linenums"). template: '<h1>{{title}}</h1><h2>{{hero}} details!</h2>' :markdown The browser should refresh and display our title and hero. The double curly braces tell our app to read the `title` and `hero` properties from the component and render them. This is the "interpolation" form of one-way data binding; we can learn more about interpolation in the [Displaying Data chapter](displaying-data). ## Hero Object At the moment, our hero is just a name. Our hero needs more properties. Let's convert the `hero` from a literal string to a class. Create a `Hero` class with `id` and `name` properties. Keep this near the top of hte `app.ts` file for now. ``` class Hero { id: number; name: string; } ``` Now that we have a `Hero` class, let’s refactor our component’s `hero` property to be of type `Hero`. Then initialize it with an id of `1` and the name, "Windstorm". ``` public hero: Hero = { id: 1, name: 'Windstorm' }; ``` Because we changed the hero from a string to an object, we update the binding in the template to refer to the hero’s `name` property. code-example(format="linenums"). template: '<h1>{{title}}</h1><h2>{{hero.name}} details!</h2>' :markdown The browser refreshes and continues to display our hero’s name. ## **Adding more HTML** Displaying a name is good, but we want to see all of our hero’s properties. We’ll add a `
` for our hero’s `id` property and another `
` for our hero’s `name`. code-example(format="linenums"). template: '<h1>{{title}}</h1><h2>{{hero.name}} details!</h2><div><label>id: </label>{{hero.id}}</div><div><label>name: </label>{{hero.name}}</div>' :markdown Uh oh, our template string is getting long. We better take care of that to avoid the risk of making a typo in the template. ### Multi-line Template Strings We could make a more readable template with string concatenation but that gets ugly fast, it is harder to read, and it is easy to make a spelling error. Instead, let’s take advantage of the template strings feature in ES2015 and TypeScript to maintain our sanity. Change the quotes around the template to back-ticks and put the `

`, `

` and `
` elements on their own lines. code-example(format="linenums"). template:` <h1>{{title}}</h1> <h2>{{hero.name}} details!</h2> <div><label>id: </label>{{hero.id}}</div> <div><label>name: </label>{{hero.name}}</div> ` .callout.is-important header A back-tick is not a single quote :markdown **Be careful!** A back-tick (`) looks a lot like a single quote ('). It's actually a completely different character. Back-ticks can do more than demarcate a string. Here we use them in a limited way to spread the template over multiple lines. Everything between the back-ticks at the beginning and end of the template is part of a single template string. .l-main-section :markdown # Editing Our Hero We want to be able to edit the hero name in a textbox. Replace the hero name `