include ../_util-fns :marked # Once Upon a Time Every story starts somewhere. Our story starts where the [QuickStart](../quickstart.html) ends. :marked 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: .filetree .file angular2_tour_of_heroes .children .file lib .children .file app_component.dart .file web .children .file index.html .file main.dart .file styles.css .file pubspec.yaml .p   .callout.is-helpful header Source code :marked Run the for this part. :marked ## Keep the app compiling and running We want to start the Dart compiler, have it watch for changes, and start our server. We'll do this by typing code-example(language="bash"). pub serve :marked This command runs the compiler in watch mode, starts the server, and keeps the app running while we continue to build the Tour of Heroes. .l-main-section :marked ## 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". +makeExample('toh-1/dart-snippets/app_component_snippets_pt1.dart', 'app-component-1', 'app_component.dart (AppComponent class)')(format=".") :marked Now we update the template in the `@Component` annotation with data bindings to these new properties. +makeExample('toh-1/dart-snippets/app_component_snippets_pt1.dart', 'show-hero') :marked 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. .l-sub-section :marked Learn more about interpolation in the [Displaying Data chapter](../guide/displaying-data.html). :marked ### 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 the `app_component.dart` file for now. +makeExample('toh-1/dart/lib/app_component.dart', 'hero-class-1', 'app_component.dart (Hero class)')(format=".") :marked 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". +makeExample('toh-1/dart/lib/app_component.dart', 'hero-property-1', 'app_component.dart (hero property)')(format=".") :marked 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. +makeExample('toh-1/dart-snippets/app_component_snippets_pt1.dart', 'show-hero-2') :marked 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`. +makeExample('toh-1/dart-snippets/app_component_snippets_pt1.dart', 'show-hero-properties') :marked 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 Dart to maintain our sanity. Change the quotes around the template to triple quotes and put the `

`, `

` and `
` elements on their own lines. +makeExample('toh-1/dart-snippets/app_component_snippets_pt1.dart', 'multi-line-strings', 'app_component.dart (AppComponent\'s template)')(format=".") // omit back-tick warning .l-main-section :marked ## Editing Our Hero We want to be able to edit the hero name in a textbox. Refactor the hero name `