Merge branch 'master' into kwalrath-dart-25

Conflicts:
	public/docs/dart/latest/quickstart.jade
This commit is contained in:
Kathy Walrath 2015-06-05 11:18:27 -07:00
commit 1d06a4a6fc
1 changed files with 172 additions and 124 deletions

View File

@ -7,13 +7,20 @@
p. p.
These instructions assume that you already have the Dart SDK These instructions assume that you already have the
<a href="https://www.dartlang.org/downloads/">Dart SDK</a>
and any tools you like to use with Dart. and any tools you like to use with Dart.
If not, go If you don't have a favorite editor already, try
<a href="https://www.dartlang.org/downloads/">download Dart</a>. <a href="https://confluence.jetbrains.com/display/WI/Getting+started+with+Dart">WebStorm</a>,
Then return here. which comes with a Dart plugin.
You can also download
<a href="https://www.dartlang.org/tools/">Dart plugins for
other IDEs and editors</a>.
// STEP 1 - Create a project ########################## p.
Once you have the Dart SDK and any other tools you want, return here.
//- STEP 1 - Create a project ##########################
.l-main-section .l-main-section
h2#section-install-angular 1. Create a project h2#section-install-angular 1. Create a project
@ -21,38 +28,39 @@ p.
Create a new directory, and put a file named Create a new directory, and put a file named
<code>pubspec.yaml</code> in it. <code>pubspec.yaml</code> in it.
pre.prettyprint code-example(language="sh").
code. &gt; <span class="blk">mkdir hello_world</span>
&gt; mkdir hello_world &gt; <span class="blk">cd hello_world</span>
&gt; cd hello_world &gt; <span class="blk">vim pubspec.yaml</span> # Use your favorite editor!
&gt; vim pubspec.yaml # Use your favorite editor!
p. p.
In <code>pubspec.yaml</code>, add the angular2 and browser packages as dependencies. In <code>pubspec.yaml</code>,
Angular 2 is changing rapidly, so specify an exact version: specify the angular2 and browser packages as dependencies,
<b>2.0.0-alpha.26</b>. as well as the angular2 transformer.
Angular 2 is changing rapidly, so provide an exact version:
<b>2.0.0-alpha.25</b>.
pre.prettyprint.linenums.lang-basic code-example(language="yaml" format="linenums").
code. name: hello_world
name: hello_world version: 0.0.1
version: 0.0.1 dependencies:
dependencies: angular2: 2.0.0-alpha.25
angular2: 2.0.0-alpha.26 browser: ^0.10.0+2
browser: any transformers:
- angular2:
entry_points: web/main.dart
p. p.
In the same directory, run <code>pub get</code> In the same directory, run <code>pub get</code>
to install the angular2 and browser packages to install the angular2 and browser packages
(along with the packages they depend on): (along with the packages they depend on):
pre.prettyprint.lang-basic code-example(language="sh").
code. &gt; <span class="blk">pub get</span>
&gt; pub get
// PENDING: Create template? Link to pub/pubspec docs? //- PENDING: Create template? Link to pub/pubspec docs?
// Is browser really needed?
// STEP 2 - Import Angular ########################## //- STEP 2 - Import Angular ##########################
.l-main-section .l-main-section
h2#section-transpile 2. Import Angular h2#section-transpile 2. Import Angular
@ -60,27 +68,20 @@ p.
Still in the same directory, create a <code>web</code> directory. Still in the same directory, create a <code>web</code> directory.
Create a file under <code>web</code> named <code>main.dart</code>. Create a file under <code>web</code> named <code>main.dart</code>.
pre.prettyprint code-example(language="sh").
code. &gt; <span class="blk">mkdir web</span>
&gt; mkdir web &gt; <span class="blk">vim web/main.dart</span> # Use your favorite editor!
&gt; vim web/main.dart # Use your favorite editor!
p. p.
Edit <code>web/main.dart</code> to import the angular2 library Edit <code>web/main.dart</code> to import the angular2 library
and (for now) two reflection libraries: and two reflection libraries:
// pre.prettyprint.linenums code-example(language="dart" format="linenums").
pre.prettyprint import 'package:angular2/angular2.dart';
code. import 'package:angular2/src/reflection/reflection.dart' show reflector;
import 'package:angular2/angular2.dart'; import 'package:angular2/src/reflection/reflection_capabilities.dart' show ReflectionCapabilities;
// These imports will go away soon: //- STEP 3 - Define a component ##########################
import 'package:angular2/src/reflection/reflection.dart' show reflector;
import 'package:angular2/src/reflection/reflection_capabilities.dart' show ReflectionCapabilities;
// [PENDING: add line numbers once we can specify where they start]
// STEP 3 - Define a component ##########################
.l-main-section .l-main-section
h2#section-angular-create-account 3. Define a component h2#section-angular-create-account 3. Define a component
@ -89,19 +90,16 @@ p.
Update <code>web/main.dart</code>, adding the following code Update <code>web/main.dart</code>, adding the following code
after the imports: after the imports:
pre.prettyprint code-example(language="dart" format="linenums:5").
code. @Component(
@Component( selector: 'my-app'
selector: 'my-app' )
) @View(
@View( template: '&lt;h1&gt;Hello {{ name }}&lt;/h1&gt;'
template: '&lt;h1&gt;Hello {{ name }}&lt;/h1&gt;' )
) class AppComponent {
class AppComponent { String name = 'Alice';
String name = 'Alice'; }
}
// [PENDING: add line numbers once we can specify where they start]
p. p.
The code you just added creates a component that The code you just added creates a component that
@ -125,16 +123,13 @@ p.
specify a <code>templateUrl</code> property specify a <code>templateUrl</code> property
and give it the path to the HTML file. and give it the path to the HTML file.
pre.prettyprint code-example(language="dart").
code. @Component(
@Component( selector: 'my-app'
selector: 'my-app' )
) @View(
@View( template: '&lt;h1&gt;Hello {{ name }}&lt;/h1&gt;'
template: '&lt;h1&gt;Hello {{ name }}&lt;/h1&gt;' )
)
// [PENDING: add line numbers once we can specify where they start]
p. p.
The annotations above specify an HTML tag of <code>&lt;my-app&gt;</code> The annotations above specify an HTML tag of <code>&lt;my-app&gt;</code>
@ -154,32 +149,23 @@ p.
template renders, "Hello Alice" appears instead of template renders, "Hello Alice" appears instead of
<span ng-non-bindable>"Hello {{ name }}"</span>. <span ng-non-bindable>"Hello {{ name }}"</span>.
pre.prettyprint code-example(language="dart").
code. class AppComponent {
class AppComponent { String name = 'Alice';
String name = 'Alice'; }
}
// [PENDING: add line numbers once we can specify where they start] //- STEP 4 - Bootstrap ##########################
// STEP 4 - Bootstrap ##########################
.l-main-section .l-main-section
h2#section-transpile 4. Bootstrap h2#section-transpile 4. Bootstrap
p. p.
Add the following code to the bottom of <code>web/main.dart</code>: Add the following code to the bottom of <code>web/main.dart</code>:
pre.prettyprint code-example(language="dart" format="linenums:15").
code. main() {
main() { reflector.reflectionCapabilities = new ReflectionCapabilities();
// Temporarily needed. bootstrap(AppComponent);
reflector.reflectionCapabilities = new ReflectionCapabilities(); }
bootstrap(AppComponent);
}
// [PENDING: add line numbers once we can specify where they start]
p. p.
This code adds a <code>main()</code> function This code adds a <code>main()</code> function
@ -188,13 +174,18 @@ p.
you defined above. you defined above.
p. p.
Setting the value of Setting the value of <code>reflector.reflectionCapabilities</code>
<code>reflector.reflectionCapabilities</code> lets your app use the Dart VM's reflection (dart:mirrors)
is a temporary workaround when running in Dartium.
that you can remove once Angular's transformer is available. Reflection is fast in native Dart,
so using it makes sense during development.
Later, when you build a JavaScript version of your app,
the Angular transformer will
convert the reflection-using code to static code,
so your generated JavaScript can be smaller and faster.
// STEP 5 - Declare the HTML ########################## //- STEP 5 - Declare the HTML ##########################
.l-main-section .l-main-section
h2#section-angular-create-account 5. Declare the HTML h2#section-angular-create-account 5. Declare the HTML
@ -204,53 +195,110 @@ p.
the following code, the following code,
which loads <code>main.dart</code> and instantiates the my-app component: which loads <code>main.dart</code> and instantiates the my-app component:
pre.prettyprint.linenums code-example(language="html" format="linenums").
code. &lt;!doctype html>
&lt;!doctype html> &lt;html>
&lt;html> &lt;head&gt;
&lt;head&gt; &lt;title&gt;Angular 2 Quickstart&lt;/title&gt;
&lt;title&gt;Angular 2 Quickstart&lt;/title&gt; &lt;/head&gt;
&lt;/head&gt; &lt;body>
&lt;body> &lt;my-app>&lt;/my-app>
&lt;my-app>&lt;/my-app>
&lt;script type="application/dart" src="main.dart">&lt;/script> &lt;script type="application/dart" src="main.dart">&lt;/script>
&lt;script src="packages/browser/dart.js">&lt;/script> &lt;script src="packages/browser/dart.js">&lt;/script>
&lt;/body> &lt;/body>
&lt;/html> &lt;/html>
// STEP 6 - Build and run ########################## //- STEP 6 - Run ##########################
.l-main-section .l-main-section
h2#section-angular-run-app 6. Build and run your app h2#section-angular-run-app 6. Run your app
p. p.
You have several options for running your app. You have a few options for running your app.
The quickest and easiest, for now, One is to launch a local HTTP server
is to open your project in <b>Dart Editor</b>, and then view the app in
right-click <b>web/index.html</b>, <a href="https://www.dartlang.org/tools/dartium/">Dartium</a>.
and choose <b>Open in Dartium</b>. You can use whatever server you like, such as WebStorm's server
This starts a web server or Python's SimpleHTTPServer.
and opens your app in an experimental browser that contains the Dart VM.
// TODO: screenshot? embedded app?
p. p.
Another option is to build and serve the app using <code>pub serve</code>, Another option is to build and serve the app using <code>pub serve</code>,
and then run it by visiting <b>http://localhost:8080</b> in a browser. and then run it by visiting <b>http://localhost:8080</b> in any modern browser.
Generating the JavaScript takes a few seconds when you first visit the page, Pub serve generates the JavaScript on the fly,
and the generated JavaScript is currently large. which takes a few seconds when you first visit the page.
The generated JavaScript will be smaller once
Angular's transformer becomes available.
// [PENDING: Update when transformer is working!] p.
Once the app is running,
you should see <b>Hello Alice</b> in your browser window.
// WHAT'S NEXT... ##########################
//- STEP 7 - Generate JavaScript ##########################
.l-main-section
h2#section-angular-run-app 7. Generate JavaScript
p.
Before you can deploy your app, you need to generate JavaScript files.
Compiling your Dart code to JavaScript is easy:
just run <code>pub build</code>.
code-example(language="basic").
&gt; <span class="blk">pub build</span>
Loading source assets...
Loading angular2 transformers...
INFO: Formatter is being overwritten.
Building hello_world... (3.1s)
[Info from Dart2JS]:
Compiling hello_world|web/main.dart...
[Info from Dart2JS]:
Took 0:00:16.123086 to compile hello_world|web/main.dart.
Built 41 files to "build".
//- REGENERATE THIS OUTPUT - or delete it? - when updating from 2.0.0-alpha.25
p.
The generated JavaScript appears, along with supporting files,
under the <code>build</code> directory.
p.
When you generate JavaScript for an Angular app,
be sure you use the Angular transformer.
It analyzes your code,
converting reflection-using code to static code
that Dart's build tools can compile to faster, smaller JavaScript.
The highlighted lines in <code>pubspec.yaml</code>
configure the Angular transformer:
code-example(language="yaml" format="linenums").
name: hello_world
version: 0.0.1
dependencies:
angular2: 2.0.0-alpha.25
browser: ^0.10.0+2
<span class="pnk">transformers:
- angular2:
entry_points: web/main.dart</span>
p.
The <code>entry_points</code> entry
identifies the Dart file in your app
that has a <code>main()</code> function.
For more information, see the
<a href="https://github.com/angular/angular/wiki/Angular-2-Dart-Transformer">Angular
transformer wiki page</a>.
//- WHAT'S NEXT... ##########################
.l-main-section .l-main-section
h2#section-transpile Great job! Next step... h2#section-transpile Great job! Next step...
p. p.
We plan to add a developer guide soon. Follow the <a href="guide">developer guide</a>
Until then, check out <a href="resources.html">Angular Resources</a>. to continue playing with Angular 2 for Dart.
To learn more about Dart, go to
<a href="https://www.dartlang.org">dartlang.org</a>. p.
Or read more about Angular or Dart:
ul
li
<a href="resources.html">Angular resources</a>
li
<a href="https://www.dartlang.org">dartlang.org</a>