2016-02-06 02:27:06 -05:00
include ../_util-fns
2015-10-09 15:18:47 -04:00
2016-04-08 00:11:13 -04:00
// #docregion intro
2015-11-10 13:31:46 -05:00
:marked
2015-11-01 00:13:18 -04:00
# Tour of Heroes: the vision
2016-06-15 11:31:28 -04:00
2016-04-17 11:31:22 -04:00
# 《英雄指南》目标概览
2015-11-01 00:13:18 -04:00
Our grand plan is to build an app to help a staffing agency manage its stable of heroes.
Even heroes need to find work.
2016-04-12 07:07:06 -04:00
2016-09-15 05:08:17 -04:00
我们的终极计划是构建一个程序,来帮助英雄管理局管理英雄围栏(译注: 比如WoW登录后看到的那个列表就是“英雄围栏”)。毕竟,英雄们也得养家糊口嘛!
2015-11-01 00:13:18 -04:00
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.
2016-05-15 09:27:57 -04:00
当然,在本教程中,我们只完成一小步。我们这次构建的应用会涉及很多特性:获得并显示英雄列表,编辑所选英雄的详情,并在英雄数据的多个视图之间建立导航。这些特性,在成熟的、数据驱动的应用中经常见到。
2016-04-12 07:07:06 -04:00
2015-11-01 00:13:18 -04:00
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
2016-03-07 23:14:38 -05:00
with two-way data binding. We'll bind component methods to user events like key strokes and clicks.
2015-11-01 00:13:18 -04:00
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. We'll create a shared service to assemble our heroes. And we'll use routing to navigate among different views and their components.
2016-05-15 09:27:57 -04:00
这篇《英雄指南》覆盖了Angular的核心原理。
2016-09-16 23:46:17 -04:00
我们将使用内置指令来显示/隐藏元素,并且显示英雄数据的列表。
2016-04-12 07:07:06 -04:00
我们将创建一个组件来显示英雄的详情,另一个组件则用来显示英雄列表。
2016-05-11 06:58:41 -04:00
我们将对只读数据使用单向数据绑定。我们将添加一些可编辑字段,并通过双向数据绑定更新模型。
2016-04-12 07:07:06 -04:00
我们将把组件上的方法绑定到用户事件上,比如按键和点击。
我们将学习从主列表视图中选择一个英雄,然后在详情视图中编辑它。
我们将通过管道对数据进行格式化。
我们将创建一个共享服务来管理我们的英雄们。
我们将使用路由在不同的视图及其组件之间进行导航。
2015-11-01 00:13:18 -04:00
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.
2016-04-12 07:07:06 -04:00
2016-05-11 07:25:40 -04:00
我们将学习足够的Angular核心技术, 来作为起步, 并建立信心 —— 证明Angular确实能做到我们想让它做的。
虽然我们将覆盖大部分“简介级”知识,但还是会放上大量链接,指向更深入的章节。
2015-12-16 21:47:02 -05:00
2016-07-03 20:11:17 -04:00
Run the <live-example name="toh-6"></live-example>.
2016-07-06 20:15:51 -04:00
运行<live-example name="toh-6"></live-example>。
2015-11-10 13:31:46 -05:00
2016-07-03 20:11:17 -04:00
// #enddocregion intro
2015-11-10 13:31:46 -05:00
2016-04-08 00:11:13 -04:00
// #docregion main
2015-10-16 04:06:56 -04:00
.l-main-section
2015-11-10 13:31:46 -05:00
:marked
2015-11-01 00:13:18 -04:00
## The End Game
2016-06-15 11:31:28 -04:00
2016-04-23 10:23:31 -04:00
## 游戏的终点
2015-10-12 21:36:33 -04:00
2015-11-01 00:13:18 -04:00
Here's a visual idea of where we're going in this tour, beginning with the "Dashboard"
view and our most heroic heroes:
2016-04-12 07:07:06 -04:00
2016-06-13 21:26:54 -04:00
在本教程中,还引入了一些可视化思想:放一个“仪表盘(Dashboard)”视图,来展示我们最勇敢的英雄。
2015-10-09 15:18:47 -04:00
2015-11-01 00:13:18 -04:00
figure.image-display
2016-04-17 11:31:22 -04:00
img(src='/resources/images/devguide/toh/heroes-dashboard-1.png' alt="英雄仪表盘的输出")
2015-10-09 15:18:47 -04:00
2015-11-10 13:31:46 -05:00
:marked
2015-11-01 00:13:18 -04:00
Above the dashboard are two links ("Dashboard" and "Heroes").
We could click them to navigate between this Dashboard and a Heroes view.
2015-10-12 21:36:33 -04:00
2016-04-17 11:31:22 -04:00
这个仪表盘中有两个链接:“仪表盘”和“英雄”。
2016-05-11 07:25:40 -04:00
我们将点击它们在“仪表盘”和“英雄”视图之间导航。
2016-04-12 07:07:06 -04:00
2015-11-01 00:13:18 -04:00
Instead we click the dashboard hero named "Magneta" and the router takes us to a "Hero Details" view
of that hero where we can change the hero's name.
2015-11-10 13:31:46 -05:00
2016-04-17 11:31:22 -04:00
当我们点击仪表盘上名叫“Magneta”的英雄时, 路由将把我们带到这个英雄的详情页, 在这里, 我们可以修改英雄的名字。
2016-04-12 07:07:06 -04:00
2015-11-01 00:13:18 -04:00
figure.image-display
2016-04-12 07:07:06 -04:00
img(src='/resources/images/devguide/toh/hero-details-1.png' alt="英雄详情的输出")
2015-10-09 15:18:47 -04:00
2015-11-10 13:31:46 -05:00
:marked
2016-01-18 01:49:41 -05:00
Clicking the "Back" button would return us to the "Dashboard".
2015-11-01 00:13:18 -04:00
Links at the top can take us to either of the main views.
2016-01-18 01:49:41 -05:00
We'll click "Heroes". The app takes to the "Heroes" master list view.
2015-10-15 21:51:10 -04:00
2016-06-13 21:26:54 -04:00
点击“后退(Back)”按钮将把我们带回“仪表盘”。
2016-04-12 07:07:06 -04:00
顶部的链接可以把我们带到任何一个主视图。
如果我们点击“英雄”链接,本应用将把我们带到“英雄”列表主视图。
2015-11-01 00:13:18 -04:00
figure.image-display
2016-04-12 07:07:06 -04:00
img(src='/resources/images/devguide/toh/heroes-list-2.png' alt="英雄列表的输出")
2015-10-15 21:51:10 -04:00
2015-11-10 13:31:46 -05:00
:marked
2015-11-01 00:13:18 -04:00
We click a different hero and the readonly mini-detail beneath the list reflects our new choice.
2016-04-12 07:07:06 -04:00
2016-05-11 07:25:40 -04:00
当我们点击另一位英雄时,一个只读的“微型视图”会显示在列表下方,以体现我们的选择。
2015-11-10 13:31:46 -05:00
2015-11-01 00:13:18 -04:00
We click the "View Details" button to drill into the
editable details of our selected hero.
2016-04-12 07:07:06 -04:00
我们可以点击其中的“查看详情”按钮来进入所选英雄的“编辑视图”。
2015-11-10 13:31:46 -05:00
2015-11-01 00:13:18 -04:00
The following diagram captures all of our navigation options.
2016-04-12 07:07:06 -04:00
2016-05-16 01:43:32 -04:00
下面这张图汇总了我们所有可能的导航路径。
2015-11-01 00:13:18 -04:00
figure.image-display
2016-04-12 07:07:06 -04:00
img(src='/resources/images/devguide/toh/nav-diagram.png' alt="查看导航")
2015-10-15 21:51:10 -04:00
2015-11-10 13:31:46 -05:00
:marked
2015-11-07 15:27:13 -05:00
Here's our app in action
2016-04-12 07:07:06 -04:00
2016-05-11 07:25:40 -04:00
下图演示了我们应用中的所有操作。
2015-11-10 13:31:46 -05:00
2015-11-07 15:27:13 -05:00
figure.image-display
2016-04-17 11:31:22 -04:00
img(src='/resources/images/devguide/toh/toh-anim.gif' alt="英雄指南的所有动作")
2015-11-10 13:31:46 -05:00
2015-10-16 04:06:56 -04:00
.l-main-section
2015-11-10 13:31:46 -05:00
:marked
2015-12-15 01:43:38 -05:00
## Up Next
2016-06-15 11:31:28 -04:00
2016-04-12 07:07:06 -04:00
## 接下来
2015-11-01 00:13:18 -04:00
We’ ll build this Tour of Heroes together, step by step.
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 21:04:43 -05:00
We'll motivate each step with a requirement that we've
2015-11-01 00:13:18 -04:00
met in countless applications. Everything has a reason.
2015-10-09 15:18:47 -04:00
2016-05-11 07:25:40 -04:00
让我们一起,一步步构建出《英雄指南》。
我们将让和无数应用类似的需求,驱动我们走向下一步。任何事,都会有理由。
2016-04-12 07:07:06 -04:00
2015-11-01 00:13:18 -04:00
And we’ ll meet many of the core fundamentals of Angular along the way.
2016-04-12 07:07:06 -04:00
2016-05-11 07:25:40 -04:00
这一路上, 我们将遇到很多Angular核心原理。
2015-10-09 15:18:47 -04:00
2015-11-01 00:13:18 -04:00
[Let's get started!](./toh-pt1.html)
2016-04-12 07:07:06 -04:00
[勇敢的前进吧!](./toh-pt1.html)
2016-04-08 00:11:13 -04:00
// #enddocregion main