.l-main-section p. As long as you already have the Dart SDK, getting started with Angular 2 is simple: ol li Depend on the angular2 pub package. li Create a Dart file that defines (directly or indirectly) a root component and bootstraps Angular. li Create an HTML file that uses the root component and points to the Dart file p. You can use whichever editor or IDE you like, or just use the command-line tools that the Dart SDK provides. See Dart Tools for more information. h2#section-install Depend on angular2 p. To use Angular2 in your app, include angular2 as a dependency in your app's pubspec.yaml file. For example: code-example(language="yaml"). # pubspec.yaml name: getting_started description: Getting Started example version: 0.0.1 dependencies: angular2: 2.0.0-alpha.39 browser: ^0.10.0 transformers: - angular2: entry_points: web/main.dart p. Run pub get to download the packages your app depends on. (Dart-savvy editors and IDEs typically run pub get for you.) .l-main-section h2#section-set-up-the-starting-component Write the Dart code p. Next to your pubspec.yaml file, create a web subdirectory containing a Dart file (main.dart). Edit main.dart, adding a component class (AppComponent), configuring it to bind to the <my-app> element, and creating a top-level main() function that calls Angular's bootstrap() function. code-example(language="dart" escape="html"). // web/main.dart import 'package:angular2/angular2.dart'; import 'package:angular2/bootstrap.dart'; @Component(selector: 'my-app') @View(template: '

My first Angular 2 App

') class AppComponent {} main() { bootstrap(AppComponent); } .l-main-section h2#section-create-an-entry-point Create an HTML file p. In the web/ directory of your app, create an HTML file (index.html). Edit index.html to add a <my-app> element and call main.dart. code-example(language="html"). <!-- web/index.html --> <!DOCTYPE html> <html> <head> <title>Getting Started</title> <link rel="stylesheet" href="style.css"> <script async src="main.dart" type="application/dart"></script> <script async src="packages/browser/dart.js"></script> </head> <body> <my-app></my-app> </body> </html> .l-main-section h2#section-run-it Run the app! p. Now run the app. How you do this depends on your tools. ul li. If you're using WebStorm or IntelliJ IDEA, right-click web/index.html, and choose Run 'index.html'. li. If you're using the command line and don't have Dartium, serve the app using pub serve, and then run it by visiting http://localhost:8080 in a browser. Generating the JavaScript takes a few seconds when you first visit the page, and the generated JavaScript is currently large. The generated JavaScript will be smaller once Angular's transformer becomes available. p. You should see something like this: figure.image-display img(src='/resources/images/examples/setup-example1.png' alt="Example of Todo App") .l-main-section h2#section-explanations Explanations p This basic Angular app contains the structure for any app you'll build. .l-sub-section h3 It's all a tree p. You can think of an Angular app as a tree of components. The root component acts as the top-level container for the rest of your application. You've named this one AppComponent, but there's nothing special about the name; you can use whatever makes sense to you. p. The root component's job is to give a location in the HTML file where your application can render through its element—in this case, <my-app>. There's nothing special about the HTML filename or the element name; you can pick whatever you like. p. The root component loads the initial template for the application, which loads other components to perform whatever functions your application needs—menu bars, views, forms, and so on. We'll walk through examples of all of these in the following pages. .l-sub-section h3 @Component and @View annotations p. A component annotation describes details about the component. An annotation can be identified by its at-sign (@). p. The @Component annotation defines the HTML tag for the component by specifying the component's CSS selector. p. The @View annotation defines the HTML that represents the component. The component you wrote uses an inline template, but you can also have an external template. To use an external template, specify a templateUrl property and give it the path to the HTML file. p. Exciting! Not excited yet? Let's move on to Displaying Data.