2016-02-05 23:27:06 -08:00
|
|
|
include ../_util-fns
|
2015-10-15 00:51:24 -07:00
|
|
|
|
docs(tutorial): combines all 4 sections + revisions/updates to a.53, hides 3&4
closes #488
ToH History (oldest-to-latest):
----------------------------
created code example/snippets files for use with +makeExample, replace usage of "pre.prettyprint.lang-bash" with this: code-example(format="." language="bash").
fixed spelling errors in examples file path used by +makeExample
changed usage of "code-example" to "+makeExample"
adding code example/snippets files used in toh 1
fixed example file paths, replaced "pre.prettyprint.lang-bash" with "code-example. "
(docs) toh-pt3 initial state
created code examples for display in jade, starting conversion of Google doc and trying +makeExample rendering
all text copied from doc to jade, still some styling and formatting to perform
completed conversion and styling, moved toh3 example files to "tutorial" folder under _examples
created specific code example files for chapter toh 3 and re-pathed references in +makeExample
minor edit
docs) toh combined - initial combined commit
updated ToH for a.52
tons of changes, including de-kebab-ing, removed src folder, updated tsconfig too
fixing snippets using incorrect ending input tag
using inline html and css for the app.component.
ToH Part 1 Code: updated the imports, removed obsolete directive delcarations
ToH Code Part 1: updated to use imports, interface. will hit others soon
toh part 1: ngModel fix
toh part1: removed obsolete story that referred to how we used to have to import and declare all directives we used. yay!
ToH Part 1: updated to use `boot.ts` and `app.component.ts`. this affected the partials, snippets, and the story.
toh part 1: using `npm run go`
toh parts 1 -4: modified all places to use `npm run go`
toh part 1: refactor for jade
toh part 1: fixing the code samples
toh part 2: seeping through the story
toh part 2: fixing snippets.
toh part 2: replaced ngClass with class.selected
toh part 2: removed whitespace
toh part 2: added final state to the code
toh: fixing paths
toh part 4: fixing src/app path to app
toh part 3: fixing folder path
toh part 2: fixed typo
toh part 2: typo on ngModel
toh part 2: added ngif
toh part 2: removed old hero property. moved the details lower, where we need it
toh index: updated hero list image to show consistent styling as the other images here
QS spelling error (targes -> targets)
tweeks: space and ngIF
2015-11-15 18:04:43 -08:00
|
|
|
:marked
|
2016-11-21 17:13:21 -08:00
|
|
|
## Setup to develop locally
|
|
|
|
Follow the [setup](../guide/setup.html) instructions for creating a new project
|
2017-03-21 11:08:09 -07:00
|
|
|
named <ngio-ex path="angular-tour-of-heroes"></ngio-ex>.
|
|
|
|
|
|
|
|
The file structure should look like this:
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2015-12-14 20:05:13 -08:00
|
|
|
.filetree
|
2016-09-20 05:24:40 +02:00
|
|
|
.file angular-tour-of-heroes
|
2015-12-14 20:05:13 -08:00
|
|
|
.children
|
2017-02-02 18:38:17 +00:00
|
|
|
.file src
|
2015-12-14 20:05:13 -08:00
|
|
|
.children
|
2017-02-02 18:38:17 +00:00
|
|
|
.file app
|
|
|
|
.children
|
|
|
|
.file app.component.ts
|
|
|
|
.file app.module.ts
|
2016-01-28 16:15:26 -08:00
|
|
|
.file main.ts
|
2017-02-02 18:38:17 +00:00
|
|
|
.file index.html
|
|
|
|
.file styles.css
|
|
|
|
.file systemjs.config.js
|
|
|
|
.file tsconfig.json
|
2017-03-21 11:08:09 -07:00
|
|
|
.file node_modules ...
|
2015-12-14 20:05:13 -08:00
|
|
|
.file package.json
|
docs(tutorial): combines all 4 sections + revisions/updates to a.53, hides 3&4
closes #488
ToH History (oldest-to-latest):
----------------------------
created code example/snippets files for use with +makeExample, replace usage of "pre.prettyprint.lang-bash" with this: code-example(format="." language="bash").
fixed spelling errors in examples file path used by +makeExample
changed usage of "code-example" to "+makeExample"
adding code example/snippets files used in toh 1
fixed example file paths, replaced "pre.prettyprint.lang-bash" with "code-example. "
(docs) toh-pt3 initial state
created code examples for display in jade, starting conversion of Google doc and trying +makeExample rendering
all text copied from doc to jade, still some styling and formatting to perform
completed conversion and styling, moved toh3 example files to "tutorial" folder under _examples
created specific code example files for chapter toh 3 and re-pathed references in +makeExample
minor edit
docs) toh combined - initial combined commit
updated ToH for a.52
tons of changes, including de-kebab-ing, removed src folder, updated tsconfig too
fixing snippets using incorrect ending input tag
using inline html and css for the app.component.
ToH Part 1 Code: updated the imports, removed obsolete directive delcarations
ToH Code Part 1: updated to use imports, interface. will hit others soon
toh part 1: ngModel fix
toh part1: removed obsolete story that referred to how we used to have to import and declare all directives we used. yay!
ToH Part 1: updated to use `boot.ts` and `app.component.ts`. this affected the partials, snippets, and the story.
toh part 1: using `npm run go`
toh parts 1 -4: modified all places to use `npm run go`
toh part 1: refactor for jade
toh part 1: fixing the code samples
toh part 2: seeping through the story
toh part 2: fixing snippets.
toh part 2: replaced ngClass with class.selected
toh part 2: removed whitespace
toh part 2: added final state to the code
toh: fixing paths
toh part 4: fixing src/app path to app
toh part 3: fixing folder path
toh part 2: fixed typo
toh part 2: typo on ngModel
toh part 2: added ngif
toh part 2: removed old hero property. moved the details lower, where we need it
toh index: updated hero list image to show consistent styling as the other images here
QS spelling error (targes -> targets)
tweeks: space and ngIF
2015-11-15 18:04:43 -08:00
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
When you're done with this page, the app should look like this <live-example></live-example>.
|
2016-11-21 17:13:21 -08:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
a#keep-transpiling
|
|
|
|
:marked
|
docs(tutorial): combines all 4 sections + revisions/updates to a.53, hides 3&4
closes #488
ToH History (oldest-to-latest):
----------------------------
created code example/snippets files for use with +makeExample, replace usage of "pre.prettyprint.lang-bash" with this: code-example(format="." language="bash").
fixed spelling errors in examples file path used by +makeExample
changed usage of "code-example" to "+makeExample"
adding code example/snippets files used in toh 1
fixed example file paths, replaced "pre.prettyprint.lang-bash" with "code-example. "
(docs) toh-pt3 initial state
created code examples for display in jade, starting conversion of Google doc and trying +makeExample rendering
all text copied from doc to jade, still some styling and formatting to perform
completed conversion and styling, moved toh3 example files to "tutorial" folder under _examples
created specific code example files for chapter toh 3 and re-pathed references in +makeExample
minor edit
docs) toh combined - initial combined commit
updated ToH for a.52
tons of changes, including de-kebab-ing, removed src folder, updated tsconfig too
fixing snippets using incorrect ending input tag
using inline html and css for the app.component.
ToH Part 1 Code: updated the imports, removed obsolete directive delcarations
ToH Code Part 1: updated to use imports, interface. will hit others soon
toh part 1: ngModel fix
toh part1: removed obsolete story that referred to how we used to have to import and declare all directives we used. yay!
ToH Part 1: updated to use `boot.ts` and `app.component.ts`. this affected the partials, snippets, and the story.
toh part 1: using `npm run go`
toh parts 1 -4: modified all places to use `npm run go`
toh part 1: refactor for jade
toh part 1: fixing the code samples
toh part 2: seeping through the story
toh part 2: fixing snippets.
toh part 2: replaced ngClass with class.selected
toh part 2: removed whitespace
toh part 2: added final state to the code
toh: fixing paths
toh part 4: fixing src/app path to app
toh part 3: fixing folder path
toh part 2: fixed typo
toh part 2: typo on ngModel
toh part 2: added ngif
toh part 2: removed old hero property. moved the details lower, where we need it
toh index: updated hero list image to show consistent styling as the other images here
QS spelling error (targes -> targets)
tweeks: space and ngIF
2015-11-15 18:04:43 -08:00
|
|
|
## Keep the app transpiling and running
|
2017-03-21 11:08:09 -07:00
|
|
|
Enter the following command in the terminal window:
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2016-11-21 17:13:21 -08:00
|
|
|
code-example(language="sh" class="code-shell").
|
2015-12-16 08:16:16 -08:00
|
|
|
npm start
|
2015-10-15 00:51:24 -07:00
|
|
|
|
docs(tutorial): combines all 4 sections + revisions/updates to a.53, hides 3&4
closes #488
ToH History (oldest-to-latest):
----------------------------
created code example/snippets files for use with +makeExample, replace usage of "pre.prettyprint.lang-bash" with this: code-example(format="." language="bash").
fixed spelling errors in examples file path used by +makeExample
changed usage of "code-example" to "+makeExample"
adding code example/snippets files used in toh 1
fixed example file paths, replaced "pre.prettyprint.lang-bash" with "code-example. "
(docs) toh-pt3 initial state
created code examples for display in jade, starting conversion of Google doc and trying +makeExample rendering
all text copied from doc to jade, still some styling and formatting to perform
completed conversion and styling, moved toh3 example files to "tutorial" folder under _examples
created specific code example files for chapter toh 3 and re-pathed references in +makeExample
minor edit
docs) toh combined - initial combined commit
updated ToH for a.52
tons of changes, including de-kebab-ing, removed src folder, updated tsconfig too
fixing snippets using incorrect ending input tag
using inline html and css for the app.component.
ToH Part 1 Code: updated the imports, removed obsolete directive delcarations
ToH Code Part 1: updated to use imports, interface. will hit others soon
toh part 1: ngModel fix
toh part1: removed obsolete story that referred to how we used to have to import and declare all directives we used. yay!
ToH Part 1: updated to use `boot.ts` and `app.component.ts`. this affected the partials, snippets, and the story.
toh part 1: using `npm run go`
toh parts 1 -4: modified all places to use `npm run go`
toh part 1: refactor for jade
toh part 1: fixing the code samples
toh part 2: seeping through the story
toh part 2: fixing snippets.
toh part 2: replaced ngClass with class.selected
toh part 2: removed whitespace
toh part 2: added final state to the code
toh: fixing paths
toh part 4: fixing src/app path to app
toh part 3: fixing folder path
toh part 2: fixed typo
toh part 2: typo on ngModel
toh part 2: added ngif
toh part 2: removed old hero property. moved the details lower, where we need it
toh index: updated hero list image to show consistent styling as the other images here
QS spelling error (targes -> targets)
tweeks: space and ngIF
2015-11-15 18:04:43 -08:00
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
This command runs the TypeScript compiler in "watch mode", recompiling automatically when the code changes.
|
|
|
|
The command simultaneously launches the app in a browser and refreshes the browser when the code changes.
|
|
|
|
|
|
|
|
You can keep building the Tour of Heroes without pausing to recompile or refresh the browser.
|
2015-10-15 00:51:24 -07:00
|
|
|
|
|
|
|
.l-main-section
|
2015-11-10 18:31:46 +00:00
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
## Show the hero
|
|
|
|
Add two properties to the `AppComponent`: a `title` property for the app name and a `hero` property
|
|
|
|
for a hero named "Windstorm."
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
+makeExample('toh-1/ts/app/app.component.1.ts', 'app-component-1', 'app.component.ts (AppComponent class)')(format=".")
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2015-11-10 18:31:46 +00:00
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
Now update the template in the `@Component` decorator with data bindings to these new properties.
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
+makeExample('toh-1/ts/app/app.component.1.ts', 'show-hero', 'app.component.ts (@Component)')(format='.')
|
2015-12-14 20:05:13 -08:00
|
|
|
|
2015-11-10 18:31:46 +00:00
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
The browser refreshes and displays the title and hero name.
|
|
|
|
|
|
|
|
The double curly braces are Angular's *interpolation binding* syntax.
|
|
|
|
These interpolation bindings present the component's `title` and `hero` property values,
|
|
|
|
as strings, inside the HTML header tags.
|
2015-10-15 00:51:24 -07:00
|
|
|
|
docs(tutorial): combines all 4 sections + revisions/updates to a.53, hides 3&4
closes #488
ToH History (oldest-to-latest):
----------------------------
created code example/snippets files for use with +makeExample, replace usage of "pre.prettyprint.lang-bash" with this: code-example(format="." language="bash").
fixed spelling errors in examples file path used by +makeExample
changed usage of "code-example" to "+makeExample"
adding code example/snippets files used in toh 1
fixed example file paths, replaced "pre.prettyprint.lang-bash" with "code-example. "
(docs) toh-pt3 initial state
created code examples for display in jade, starting conversion of Google doc and trying +makeExample rendering
all text copied from doc to jade, still some styling and formatting to perform
completed conversion and styling, moved toh3 example files to "tutorial" folder under _examples
created specific code example files for chapter toh 3 and re-pathed references in +makeExample
minor edit
docs) toh combined - initial combined commit
updated ToH for a.52
tons of changes, including de-kebab-ing, removed src folder, updated tsconfig too
fixing snippets using incorrect ending input tag
using inline html and css for the app.component.
ToH Part 1 Code: updated the imports, removed obsolete directive delcarations
ToH Code Part 1: updated to use imports, interface. will hit others soon
toh part 1: ngModel fix
toh part1: removed obsolete story that referred to how we used to have to import and declare all directives we used. yay!
ToH Part 1: updated to use `boot.ts` and `app.component.ts`. this affected the partials, snippets, and the story.
toh part 1: using `npm run go`
toh parts 1 -4: modified all places to use `npm run go`
toh part 1: refactor for jade
toh part 1: fixing the code samples
toh part 2: seeping through the story
toh part 2: fixing snippets.
toh part 2: replaced ngClass with class.selected
toh part 2: removed whitespace
toh part 2: added final state to the code
toh: fixing paths
toh part 4: fixing src/app path to app
toh part 3: fixing folder path
toh part 2: fixed typo
toh part 2: typo on ngModel
toh part 2: added ngif
toh part 2: removed old hero property. moved the details lower, where we need it
toh index: updated hero list image to show consistent styling as the other images here
QS spelling error (targes -> targets)
tweeks: space and ngIF
2015-11-15 18:04:43 -08:00
|
|
|
.l-sub-section
|
2015-11-14 00:22:26 -08:00
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
Read more about interpolation in the [Displaying Data](../guide/displaying-data.html) page.
|
|
|
|
|
docs(tutorial): combines all 4 sections + revisions/updates to a.53, hides 3&4
closes #488
ToH History (oldest-to-latest):
----------------------------
created code example/snippets files for use with +makeExample, replace usage of "pre.prettyprint.lang-bash" with this: code-example(format="." language="bash").
fixed spelling errors in examples file path used by +makeExample
changed usage of "code-example" to "+makeExample"
adding code example/snippets files used in toh 1
fixed example file paths, replaced "pre.prettyprint.lang-bash" with "code-example. "
(docs) toh-pt3 initial state
created code examples for display in jade, starting conversion of Google doc and trying +makeExample rendering
all text copied from doc to jade, still some styling and formatting to perform
completed conversion and styling, moved toh3 example files to "tutorial" folder under _examples
created specific code example files for chapter toh 3 and re-pathed references in +makeExample
minor edit
docs) toh combined - initial combined commit
updated ToH for a.52
tons of changes, including de-kebab-ing, removed src folder, updated tsconfig too
fixing snippets using incorrect ending input tag
using inline html and css for the app.component.
ToH Part 1 Code: updated the imports, removed obsolete directive delcarations
ToH Code Part 1: updated to use imports, interface. will hit others soon
toh part 1: ngModel fix
toh part1: removed obsolete story that referred to how we used to have to import and declare all directives we used. yay!
ToH Part 1: updated to use `boot.ts` and `app.component.ts`. this affected the partials, snippets, and the story.
toh part 1: using `npm run go`
toh parts 1 -4: modified all places to use `npm run go`
toh part 1: refactor for jade
toh part 1: fixing the code samples
toh part 2: seeping through the story
toh part 2: fixing snippets.
toh part 2: replaced ngClass with class.selected
toh part 2: removed whitespace
toh part 2: added final state to the code
toh: fixing paths
toh part 4: fixing src/app path to app
toh part 3: fixing folder path
toh part 2: fixed typo
toh part 2: typo on ngModel
toh part 2: added ngif
toh part 2: removed old hero property. moved the details lower, where we need it
toh index: updated hero list image to show consistent styling as the other images here
QS spelling error (targes -> targets)
tweeks: space and ngIF
2015-11-15 18:04:43 -08:00
|
|
|
:marked
|
|
|
|
### Hero object
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
The hero needs more properties.
|
|
|
|
Convert the `hero` from a literal string to a class.
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2016-03-24 13:31:27 +01:00
|
|
|
Create a `Hero` class with `id` and `name` properties.
|
2017-03-21 11:08:09 -07:00
|
|
|
Add these properties near the top of the `app.component.ts` file, just below the import statement.
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-02-02 18:38:17 +00:00
|
|
|
+makeExample('toh-1/ts/src/app/app.component.ts', 'hero-class-1', 'src/app/app.component.ts (Hero class)')(format=".")
|
2015-10-15 00:51:24 -07:00
|
|
|
|
docs(tutorial): combines all 4 sections + revisions/updates to a.53, hides 3&4
closes #488
ToH History (oldest-to-latest):
----------------------------
created code example/snippets files for use with +makeExample, replace usage of "pre.prettyprint.lang-bash" with this: code-example(format="." language="bash").
fixed spelling errors in examples file path used by +makeExample
changed usage of "code-example" to "+makeExample"
adding code example/snippets files used in toh 1
fixed example file paths, replaced "pre.prettyprint.lang-bash" with "code-example. "
(docs) toh-pt3 initial state
created code examples for display in jade, starting conversion of Google doc and trying +makeExample rendering
all text copied from doc to jade, still some styling and formatting to perform
completed conversion and styling, moved toh3 example files to "tutorial" folder under _examples
created specific code example files for chapter toh 3 and re-pathed references in +makeExample
minor edit
docs) toh combined - initial combined commit
updated ToH for a.52
tons of changes, including de-kebab-ing, removed src folder, updated tsconfig too
fixing snippets using incorrect ending input tag
using inline html and css for the app.component.
ToH Part 1 Code: updated the imports, removed obsolete directive delcarations
ToH Code Part 1: updated to use imports, interface. will hit others soon
toh part 1: ngModel fix
toh part1: removed obsolete story that referred to how we used to have to import and declare all directives we used. yay!
ToH Part 1: updated to use `boot.ts` and `app.component.ts`. this affected the partials, snippets, and the story.
toh part 1: using `npm run go`
toh parts 1 -4: modified all places to use `npm run go`
toh part 1: refactor for jade
toh part 1: fixing the code samples
toh part 2: seeping through the story
toh part 2: fixing snippets.
toh part 2: replaced ngClass with class.selected
toh part 2: removed whitespace
toh part 2: added final state to the code
toh: fixing paths
toh part 4: fixing src/app path to app
toh part 3: fixing folder path
toh part 2: fixed typo
toh part 2: typo on ngModel
toh part 2: added ngif
toh part 2: removed old hero property. moved the details lower, where we need it
toh index: updated hero list image to show consistent styling as the other images here
QS spelling error (targes -> targets)
tweeks: space and ngIF
2015-11-15 18:04:43 -08:00
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
In the `Hero` class, refactor the component's `hero` property to be of type `Hero`,
|
|
|
|
then initialize it with an `id` of `1` and the name `Windstorm`.
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-02-02 18:38:17 +00:00
|
|
|
+makeExample('toh-1/ts/src/app/app.component.ts', 'hero-property-1', 'src/app/app.component.ts (hero property)')(format=".")
|
2015-10-15 00:51:24 -07:00
|
|
|
|
docs(tutorial): combines all 4 sections + revisions/updates to a.53, hides 3&4
closes #488
ToH History (oldest-to-latest):
----------------------------
created code example/snippets files for use with +makeExample, replace usage of "pre.prettyprint.lang-bash" with this: code-example(format="." language="bash").
fixed spelling errors in examples file path used by +makeExample
changed usage of "code-example" to "+makeExample"
adding code example/snippets files used in toh 1
fixed example file paths, replaced "pre.prettyprint.lang-bash" with "code-example. "
(docs) toh-pt3 initial state
created code examples for display in jade, starting conversion of Google doc and trying +makeExample rendering
all text copied from doc to jade, still some styling and formatting to perform
completed conversion and styling, moved toh3 example files to "tutorial" folder under _examples
created specific code example files for chapter toh 3 and re-pathed references in +makeExample
minor edit
docs) toh combined - initial combined commit
updated ToH for a.52
tons of changes, including de-kebab-ing, removed src folder, updated tsconfig too
fixing snippets using incorrect ending input tag
using inline html and css for the app.component.
ToH Part 1 Code: updated the imports, removed obsolete directive delcarations
ToH Code Part 1: updated to use imports, interface. will hit others soon
toh part 1: ngModel fix
toh part1: removed obsolete story that referred to how we used to have to import and declare all directives we used. yay!
ToH Part 1: updated to use `boot.ts` and `app.component.ts`. this affected the partials, snippets, and the story.
toh part 1: using `npm run go`
toh parts 1 -4: modified all places to use `npm run go`
toh part 1: refactor for jade
toh part 1: fixing the code samples
toh part 2: seeping through the story
toh part 2: fixing snippets.
toh part 2: replaced ngClass with class.selected
toh part 2: removed whitespace
toh part 2: added final state to the code
toh: fixing paths
toh part 4: fixing src/app path to app
toh part 3: fixing folder path
toh part 2: fixed typo
toh part 2: typo on ngModel
toh part 2: added ngif
toh part 2: removed old hero property. moved the details lower, where we need it
toh index: updated hero list image to show consistent styling as the other images here
QS spelling error (targes -> targets)
tweeks: space and ngIF
2015-11-15 18:04:43 -08:00
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
Because you changed the hero from a string to an object,
|
|
|
|
update the binding in the template to refer to the hero's `name` property.
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
+makeExample('toh-1/ts/app/app.component.1.ts', 'show-hero-2')
|
docs(tutorial): combines all 4 sections + revisions/updates to a.53, hides 3&4
closes #488
ToH History (oldest-to-latest):
----------------------------
created code example/snippets files for use with +makeExample, replace usage of "pre.prettyprint.lang-bash" with this: code-example(format="." language="bash").
fixed spelling errors in examples file path used by +makeExample
changed usage of "code-example" to "+makeExample"
adding code example/snippets files used in toh 1
fixed example file paths, replaced "pre.prettyprint.lang-bash" with "code-example. "
(docs) toh-pt3 initial state
created code examples for display in jade, starting conversion of Google doc and trying +makeExample rendering
all text copied from doc to jade, still some styling and formatting to perform
completed conversion and styling, moved toh3 example files to "tutorial" folder under _examples
created specific code example files for chapter toh 3 and re-pathed references in +makeExample
minor edit
docs) toh combined - initial combined commit
updated ToH for a.52
tons of changes, including de-kebab-ing, removed src folder, updated tsconfig too
fixing snippets using incorrect ending input tag
using inline html and css for the app.component.
ToH Part 1 Code: updated the imports, removed obsolete directive delcarations
ToH Code Part 1: updated to use imports, interface. will hit others soon
toh part 1: ngModel fix
toh part1: removed obsolete story that referred to how we used to have to import and declare all directives we used. yay!
ToH Part 1: updated to use `boot.ts` and `app.component.ts`. this affected the partials, snippets, and the story.
toh part 1: using `npm run go`
toh parts 1 -4: modified all places to use `npm run go`
toh part 1: refactor for jade
toh part 1: fixing the code samples
toh part 2: seeping through the story
toh part 2: fixing snippets.
toh part 2: replaced ngClass with class.selected
toh part 2: removed whitespace
toh part 2: added final state to the code
toh: fixing paths
toh part 4: fixing src/app path to app
toh part 3: fixing folder path
toh part 2: fixed typo
toh part 2: typo on ngModel
toh part 2: added ngif
toh part 2: removed old hero property. moved the details lower, where we need it
toh index: updated hero list image to show consistent styling as the other images here
QS spelling error (targes -> targets)
tweeks: space and ngIF
2015-11-15 18:04:43 -08:00
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
The browser refreshes and continues to display the hero's name.
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
### Adding HTML with multi-line template strings
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
To show all of the hero's properties,
|
|
|
|
add a `<div>` for the hero's `id` property and another `<div>` for the hero's `name`.
|
|
|
|
To keep the template readable, place each `<div>` on its own line.
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
The backticks around the component template let you put the `<h1>`, `<h2>`, and `<div>` elements on their own lines,
|
|
|
|
thanks to the <i>template literals</i> feature in ES2015 and TypeScript. For more information, see
|
|
|
|
<a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals" target="_blank" title="template literal">Template literals</a>.
|
docs(tutorial): combines all 4 sections + revisions/updates to a.53, hides 3&4
closes #488
ToH History (oldest-to-latest):
----------------------------
created code example/snippets files for use with +makeExample, replace usage of "pre.prettyprint.lang-bash" with this: code-example(format="." language="bash").
fixed spelling errors in examples file path used by +makeExample
changed usage of "code-example" to "+makeExample"
adding code example/snippets files used in toh 1
fixed example file paths, replaced "pre.prettyprint.lang-bash" with "code-example. "
(docs) toh-pt3 initial state
created code examples for display in jade, starting conversion of Google doc and trying +makeExample rendering
all text copied from doc to jade, still some styling and formatting to perform
completed conversion and styling, moved toh3 example files to "tutorial" folder under _examples
created specific code example files for chapter toh 3 and re-pathed references in +makeExample
minor edit
docs) toh combined - initial combined commit
updated ToH for a.52
tons of changes, including de-kebab-ing, removed src folder, updated tsconfig too
fixing snippets using incorrect ending input tag
using inline html and css for the app.component.
ToH Part 1 Code: updated the imports, removed obsolete directive delcarations
ToH Code Part 1: updated to use imports, interface. will hit others soon
toh part 1: ngModel fix
toh part1: removed obsolete story that referred to how we used to have to import and declare all directives we used. yay!
ToH Part 1: updated to use `boot.ts` and `app.component.ts`. this affected the partials, snippets, and the story.
toh part 1: using `npm run go`
toh parts 1 -4: modified all places to use `npm run go`
toh part 1: refactor for jade
toh part 1: fixing the code samples
toh part 2: seeping through the story
toh part 2: fixing snippets.
toh part 2: replaced ngClass with class.selected
toh part 2: removed whitespace
toh part 2: added final state to the code
toh: fixing paths
toh part 4: fixing src/app path to app
toh part 3: fixing folder path
toh part 2: fixed typo
toh part 2: typo on ngModel
toh part 2: added ngif
toh part 2: removed old hero property. moved the details lower, where we need it
toh index: updated hero list image to show consistent styling as the other images here
QS spelling error (targes -> targets)
tweeks: space and ngIF
2015-11-15 18:04:43 -08:00
|
|
|
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
+makeExample('toh-1/ts/app/app.component.1.ts', 'multi-line-strings', 'app.component.ts (AppComponent\'s template)')(format='.')
|
2015-10-15 00:51:24 -07:00
|
|
|
|
|
|
|
.l-main-section
|
2015-12-14 20:05:13 -08:00
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
## Edit the hero name
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
Users should be able to edit the hero name in an `<input>` textbox.
|
|
|
|
The textbox should both _display_ the hero's `name` property
|
|
|
|
and _update_ that property as the user types.
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
You need a two-way binding between the `<input>` form element and the `hero.name` property.
|
docs(tutorial): combines all 4 sections + revisions/updates to a.53, hides 3&4
closes #488
ToH History (oldest-to-latest):
----------------------------
created code example/snippets files for use with +makeExample, replace usage of "pre.prettyprint.lang-bash" with this: code-example(format="." language="bash").
fixed spelling errors in examples file path used by +makeExample
changed usage of "code-example" to "+makeExample"
adding code example/snippets files used in toh 1
fixed example file paths, replaced "pre.prettyprint.lang-bash" with "code-example. "
(docs) toh-pt3 initial state
created code examples for display in jade, starting conversion of Google doc and trying +makeExample rendering
all text copied from doc to jade, still some styling and formatting to perform
completed conversion and styling, moved toh3 example files to "tutorial" folder under _examples
created specific code example files for chapter toh 3 and re-pathed references in +makeExample
minor edit
docs) toh combined - initial combined commit
updated ToH for a.52
tons of changes, including de-kebab-ing, removed src folder, updated tsconfig too
fixing snippets using incorrect ending input tag
using inline html and css for the app.component.
ToH Part 1 Code: updated the imports, removed obsolete directive delcarations
ToH Code Part 1: updated to use imports, interface. will hit others soon
toh part 1: ngModel fix
toh part1: removed obsolete story that referred to how we used to have to import and declare all directives we used. yay!
ToH Part 1: updated to use `boot.ts` and `app.component.ts`. this affected the partials, snippets, and the story.
toh part 1: using `npm run go`
toh parts 1 -4: modified all places to use `npm run go`
toh part 1: refactor for jade
toh part 1: fixing the code samples
toh part 2: seeping through the story
toh part 2: fixing snippets.
toh part 2: replaced ngClass with class.selected
toh part 2: removed whitespace
toh part 2: added final state to the code
toh: fixing paths
toh part 4: fixing src/app path to app
toh part 3: fixing folder path
toh part 2: fixed typo
toh part 2: typo on ngModel
toh part 2: added ngif
toh part 2: removed old hero property. moved the details lower, where we need it
toh index: updated hero list image to show consistent styling as the other images here
QS spelling error (targes -> targets)
tweeks: space and ngIF
2015-11-15 18:04:43 -08:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
### Two-way binding
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
Refactor the hero name in the template so it looks like this:
|
|
|
|
+makeExample('toh-1/ts/app/app.component.1.ts', 'name-input')(format='.')
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
:marked
|
|
|
|
`[(ngModel)]` is the Angular syntax to bind the `hero.name` property
|
|
|
|
to the textbox.
|
|
|
|
Data flow _in both directions_: from the property to the textbox;
|
|
|
|
and from the textbox back to the property.
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
Unfortunately, immediately after this change, the application breaks.
|
|
|
|
If you looked in the browser console, you'd see Angular complaining that
|
|
|
|
"`ngModel` ... isn't a known property of `input`."
|
2016-08-09 17:38:25 +01:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
Although `NgModel` is a valid Angular directive, it isn't available by default.
|
|
|
|
It belongs to the optional `FormsModule`.
|
|
|
|
You must opt-in to using that module.
|
2015-11-10 18:31:46 +00:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
### Import the _FormsModule_
|
2016-08-09 17:38:25 +01:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
Open the `app.module.ts` file and import the `FormsModule` symbol from the `@angular/forms` library.
|
|
|
|
Then add the `FormsModule` to the `@NgModule` metadata's `imports` array, which contains the list
|
|
|
|
of external modules that the app uses.
|
2016-08-09 17:38:25 +01:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
The updated `AppModule` looks like this:
|
|
|
|
+makeExample('toh-1/ts/src/app/app.module.ts', '', 'app.module.ts (FormsModule import)')
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
.l-sub-section
|
|
|
|
:marked
|
|
|
|
Read more about `FormsModule` and `ngModel` in the
|
|
|
|
[Two-way data binding with ngModel](../guide/forms.html#ngModel) section of the
|
|
|
|
[Forms](../guide/forms.html) guide and the
|
|
|
|
[Two-way binding with NgModel](../guide/template-syntax.html#ngModel) section of the
|
|
|
|
[Template Syntax](../guide/template-syntax.html) guide.
|
2015-12-14 20:05:13 -08:00
|
|
|
|
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
When the browser refreshes, the app should work again.
|
|
|
|
You can edit the hero's name and see the changes reflected immediately in the `<h2>` above the textbox.
|
2015-11-10 18:31:46 +00:00
|
|
|
|
2015-10-16 01:06:56 -07:00
|
|
|
.l-main-section
|
2015-12-14 20:05:13 -08:00
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
## The road you've travelled
|
|
|
|
Take stock of what you've built.
|
2015-12-14 20:05:13 -08:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
* The Tour of Heroes app uses the double curly braces of interpolation (a type of one-way data binding)
|
|
|
|
to display the app title and properties of a `Hero` object.
|
|
|
|
* You wrote a multi-line template using ES2015's template literals to make the template readable.
|
|
|
|
* You added a two-way data binding to the `<input>` element
|
|
|
|
using the built-in `ngModel` directive. This binding both displays the hero's name and allows users to change it.
|
|
|
|
* The `ngModel` directive propagates changes to every other binding of the `hero.name`.
|
2015-10-15 00:51:24 -07:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
Your app should look like this <live-example></live-example>.
|
2016-07-03 17:11:17 -07:00
|
|
|
|
2015-12-14 20:05:13 -08:00
|
|
|
Here's the complete `app.component.ts` as it stands now:
|
docs(tutorial): combines all 4 sections + revisions/updates to a.53, hides 3&4
closes #488
ToH History (oldest-to-latest):
----------------------------
created code example/snippets files for use with +makeExample, replace usage of "pre.prettyprint.lang-bash" with this: code-example(format="." language="bash").
fixed spelling errors in examples file path used by +makeExample
changed usage of "code-example" to "+makeExample"
adding code example/snippets files used in toh 1
fixed example file paths, replaced "pre.prettyprint.lang-bash" with "code-example. "
(docs) toh-pt3 initial state
created code examples for display in jade, starting conversion of Google doc and trying +makeExample rendering
all text copied from doc to jade, still some styling and formatting to perform
completed conversion and styling, moved toh3 example files to "tutorial" folder under _examples
created specific code example files for chapter toh 3 and re-pathed references in +makeExample
minor edit
docs) toh combined - initial combined commit
updated ToH for a.52
tons of changes, including de-kebab-ing, removed src folder, updated tsconfig too
fixing snippets using incorrect ending input tag
using inline html and css for the app.component.
ToH Part 1 Code: updated the imports, removed obsolete directive delcarations
ToH Code Part 1: updated to use imports, interface. will hit others soon
toh part 1: ngModel fix
toh part1: removed obsolete story that referred to how we used to have to import and declare all directives we used. yay!
ToH Part 1: updated to use `boot.ts` and `app.component.ts`. this affected the partials, snippets, and the story.
toh part 1: using `npm run go`
toh parts 1 -4: modified all places to use `npm run go`
toh part 1: refactor for jade
toh part 1: fixing the code samples
toh part 2: seeping through the story
toh part 2: fixing snippets.
toh part 2: replaced ngClass with class.selected
toh part 2: removed whitespace
toh part 2: added final state to the code
toh: fixing paths
toh part 4: fixing src/app path to app
toh part 3: fixing folder path
toh part 2: fixed typo
toh part 2: typo on ngModel
toh part 2: added ngif
toh part 2: removed old hero property. moved the details lower, where we need it
toh index: updated hero list image to show consistent styling as the other images here
QS spelling error (targes -> targets)
tweeks: space and ngIF
2015-11-15 18:04:43 -08:00
|
|
|
|
2017-03-21 11:08:09 -07:00
|
|
|
+makeExample('toh-1/ts/src/app/app.component.ts', '', 'src/app/app.component.ts')
|
|
|
|
|
2015-11-10 18:31:46 +00:00
|
|
|
|
2015-10-16 01:06:56 -07:00
|
|
|
.l-main-section
|
2015-12-14 20:05:13 -08:00
|
|
|
:marked
|
2017-03-21 11:08:09 -07:00
|
|
|
## The road ahead
|
|
|
|
In the [next tutorial page](./toh-pt2.html), you'll build on the Tour of Heroes app to display a list of heroes.
|
|
|
|
You'll also allow the user to select heroes and display their details.
|
|
|
|
You'll learn more about how to retrieve lists and bind them to the template.
|