Getting started w/Angular 2 alpha.52 & TypeScript 1.7+
Jim Cummins
@JimTheDev
Developer at Fisdap
Author of Commitizen
data:image/s3,"s3://crabby-images/ff1a4/ff1a4b954c98f483fa2cca0cbdb3c50321fa7de7" alt=""
Slides: tiny.cc/angular2typescript
GitHub/Twitter: @JimTheDev
data:image/s3,"s3://crabby-images/d81b2/d81b21d36c2668003b5c4cc96cddf6f21f87efac" alt=""
Did everyone get food? Thank the sponsors!
Slides: tiny.cc/angular2typescript
Timeline
Intro
TypeScript
Angular 2
Q&A
10 min
10 min
25 min
10 min
GitHub/Twitter: @JimTheDev
Slides: tiny.cc/angular2typescript
What we won't cover
Angular 1 to 2 migration
Animations
i18n (internationalization)
GitHub/Twitter: @JimTheDev
Services (now called Providers)
Form Building (2-way binding)
Advanced TypeScript
Routing
Slides: tiny.cc/angular2typescript
<people>
<person>Jim</person>
<person>Mira</person>
<person selected>Annabelle</person>
</people>
HTML
Web in 1996: Documents
CSS
[selected] {
font-weight: bold;
}
Jim
Mira
Annabelle
Output
GitHub/Twitter: @JimTheDev
Slides: tiny.cc/angular2typescript
Web in 2015: Applications
<pets>
<pet>June</pet>
<pet>Kitteh</pet>
<pet selected>Shanti</pet>
</pets>
What if, in the same page I want selected pet to be underlined?
CSS
[selected] {
text-decoration: underline;
}
HTML
June
Kitteh
Shanti
Output
Why is Shanti bolded and underlined?
- CSS rules are global!
- We need encapsulation
- Angular 2 uses Web Components
GitHub/Twitter: @JimTheDev
Slides: tiny.cc/angular2typescript
Applications as a rat's nest of components
events
data
App
Person
Pet
People
List
GitHub/Twitter: @JimTheDev
(output)
(input)
Slides: tiny.cc/angular2typescript
GitHub/Twitter: @JimTheDev
data:image/s3,"s3://crabby-images/e44b0/e44b007c12ea174b0f651667ba49acd34bd81a17" alt=""
data:image/s3,"s3://crabby-images/85c84/85c8477909427e42bff4bec7e910db213ee7a359" alt=""
data:image/s3,"s3://crabby-images/8aeba/8aeba533da3164c7863612020463f568ff24ddd1" alt=""
data:image/s3,"s3://crabby-images/f0c21/f0c21623d9734f826cc4ea8e7e61bef0988209da" alt=""
data:image/s3,"s3://crabby-images/e6475/e647596b6c6abddc05e1be79d1fa3b71a2637c70" alt=""
data:image/s3,"s3://crabby-images/85fa5/85fa5b27ec5d92943823c2ee75995ca817de5f67" alt=""
data:image/s3,"s3://crabby-images/6cbe6/6cbe6990ce41860017e4db9cf1a21c72b8a3986a" alt=""
Infinite loop
data:image/s3,"s3://crabby-images/cffc8/cffc8120fa79b271ec40d4099ae80fee8d54c76b" alt=""
Slides: tiny.cc/angular2typescript
Applications as a component tree
event
App
PetList
Person
List
Pet
Pet
Person
Person
GitHub/Twitter: @JimTheDev
data
(output)
(input)
Slides: tiny.cc/angular2typescript
GitHub/Twitter: @JimTheDev
data:image/s3,"s3://crabby-images/911ca/911ca5b81afbe10668601fa01ffbee53ba9fe420" alt=""
data:image/s3,"s3://crabby-images/37b8f/37b8f98235c63054ea45bc4f1d2a99b5949416b7" alt=""
data:image/s3,"s3://crabby-images/c341f/c341f4881073143542c8d3fd87ae9594c5c3d8d1" alt=""
data:image/s3,"s3://crabby-images/7db96/7db96ca6271e063ccd082769067e7e70598accd1" alt=""
data:image/s3,"s3://crabby-images/8af48/8af489d9a933473528a9ff0afbd2f7c85f61fb47" alt=""
data:image/s3,"s3://crabby-images/00c0f/00c0f4f09f0c3097d4dd47c60d4a6182a1fabfa3" alt=""
data:image/s3,"s3://crabby-images/94f10/94f10d93ba3017db9e8270f6505cd2e306d3f240" alt=""
data:image/s3,"s3://crabby-images/e8163/e816383397f155ff99060fd5098c182c96142a1a" alt=""
data:image/s3,"s3://crabby-images/11a1f/11a1f526db4f64baec361cfeb75e9ab4079d871e" alt=""
Uni-directional Data flow
Slides: tiny.cc/angular2typescript
TypeScript
JavaScript
+ Types
=
GitHub/Twitter: @JimTheDev
Slides: tiny.cc/angular2typescript
Why use TypeScript?
Better overall code readability in large codebases
Ease of refactoring
IntelliSense auto suggest in code editors
data:image/s3,"s3://crabby-images/01fd4/01fd498a3208f812d62047760d792f4f42ea927a" alt=""
GitHub/Twitter: @JimTheDev
Use new ES6 features in older browsers
Slides: tiny.cc/angular2typescript
JavaScript
TypeScript
Superset
TypeScript:
Compiles TypeScript to Javascript (or shows errors)
Analyzes code to help IDEs/Editors
GitHub/Twitter: @JimTheDev
Slides: tiny.cc/angular2typescript
Hello, Annabelle!
var name = 'Annabelle';
console.log('Hello, ' + name + '!');
// > Hello, Annabelle!
var name: string = 'Annabelle';
console.log('Hello, ' + name + '!');
// > Hello, Annabelle!
JavaScript
TypeScript
GitHub/Twitter: @JimTheDev
Slides: tiny.cc/angular2typescript
Classes
class Person {
constructor(name) {
this.name = name;
}
greet() {
return 'My name is ' + this.name;
}
}
var annabelle = new Person('Annabelle');
console.log(annabelle.greet());
// > My name is Annabelle
JavaScript (ES6)
class Person {
constructor(public name: string) { }
greet(): string {
return 'My name is ' + this.name;
}
}
var annabelle = new Person('Annabelle');
console.log(annabelle.greet());
// > My name is Annabelle
TypeScript
How do we add
types using TypeScript?
GitHub/Twitter: @JimTheDev
Slides: tiny.cc/angular2typescript
Interfaces
class Person {
constructor(public name: string) { }
greet(): string {
return 'My name is ' + this.name;
}
}
var annabelle = new Person('annabelle');
console.log(annabelle.greet());
// > My name is Annabelle
TypeScript
interface Greets {
greet(): string;
}
class Person implements Greets {
constructor(public name:string) { }
greet():string {
return 'My name is ' + this.name;
}
}
var annabelle = new Person('Annabelle');
console.log(annabelle.greet());
// > My name is Annabelle
TypeScript with Interfaces
What if we want
multiple entities to
be able to greet in
different ways?
interface Greets {
greet(): string;
}
class Robot implements Greets {
constructor(public id:string) { }
greet():string {
return this.id + ' REPORTING IN';
}
}
var robbie = new Robot('MD-80');
console.log(robbie.greet());
// > MD-80 REPORTING IN
GitHub/Twitter: @JimTheDev
Slides: tiny.cc/angular2typescript
Modules
class Person {
constructor(public name: string) { }
greet() {
return 'My name is ' + this.name;
}
}
export class Person {
constructor(public name: string) { }
greet() {
return 'My name is ' + this.name;
}
}
var annabelle = new Person('Annabelle');
console.log(annabelle.greet());
// > My name is Annabelle
person.ts
app.ts
Error! Person is undefined. (app.ts:1:9)
GitHub/Twitter: @JimTheDev
import {Person} from './person';
Error! './person' has no export 'Person'. (app.ts:1:9)
Success
TypeScript Log
Slides: tiny.cc/angular2typescript
How to install TypeScript?
- Install Git
- Install Node.js v0.12 or greater
- Install TypeScript by running:
npm install -g typescript tsd
GitHub/Twitter: @JimTheDev
Slides: tiny.cc/angular2typescript
Which editors support TypeScript?
data:image/s3,"s3://crabby-images/29e80/29e80da37aee4ec5b0a8870dd423bd2f75e5e3ca" alt=""
data:image/s3,"s3://crabby-images/573ff/573ff30ac368df86486ff00d69eb6650a59fe49f" alt=""
data:image/s3,"s3://crabby-images/f286f/f286faa360a651fec448496bad30e6bf11144ae6" alt=""
data:image/s3,"s3://crabby-images/e406c/e406ca872dedac0c7d2404484adfc83b1f91d543" alt=""
data:image/s3,"s3://crabby-images/4f777/4f7774ff06323604a136fb0d915bf22ae3472085" alt=""
GitHub/Twitter: @JimTheDev
Adobe Brackets
Sublime Text
Microsoft Visual Studio Code
JetBrains
Editors
GitHub
Atom
Slides: tiny.cc/angular2typescript
TypeScript in your development pipeline.
- Command line
- IDE / Editors
- Gulp / Grunt
- Webpack / SystemJS
GitHub/Twitter: @JimTheDev
data:image/s3,"s3://crabby-images/4ea41/4ea4168bb43e538232596f0f612a2681f8e2ed6f" alt=""
Slides: tiny.cc/angular2typescript
Angular 2
=
Components
GitHub/Twitter: @JimTheDev
Slides: tiny.cc/angular2typescript
Start with a class
A Basic Component
export class Person {}
import {Component} from 'angular2/angular2';
@Component({
selector: 'person',
template: `
<hair>Black</hair>
<eyes>Brown</eyes>
`
})
export class Person {}
import {Component} from 'angular2/angular2';
@Component({
selector: 'person',
template: `
<hair>Black</hair>
<eyes>Brown</eyes>
`,
styles: `
hair { height: 150px; }
eyes { border-radius: 50%; }
`
})
export class Person {}
import {Component} from 'angular2/angular2';
@Component({
selector: 'person'
})
export class Person {}
Add a selector.
Add a template.
<person>
Usage
Selector
person
people-list
<people-list>
GitHub/Twitter: @JimTheDev
Add CSS styles
Slides: tiny.cc/angular2typescript
GitHub/Twitter: @JimTheDev
So what did we gain?
import {Component} from 'angular2/angular2';
@Component({
selector: 'person',
template: `
<hair>Black</hair>
<eyes>Brown</eyes>
`,
styles: `
hair { height: 150px; }
eyes { border-radius: 50%; }
`
})
export class Person {}
explicit dependencies
clear external API
an internal structure composed from other components
ability to visually style direct children
a place to define internal functionality
Slides: tiny.cc/angular2typescript
GitHub/Twitter: @JimTheDev
Umm...wait a minute...
import {Component} from 'angular2/angular2';
@Component({
selector: 'person',
template: `
<hair>Black</hair>
<eyes>Brown</eyes>
`,
styles: `
hair { height: 150px; }
eyes { border-radius: 50%; }
`
})
export class Person {}
We said one benefit of components is...
an internal structure composed from other components.
Hair and eyes are not components...yet.
import {Component} from 'angular2/angular2';
import {HairComponent} from '../hair/hair.component';
import {EyesComponent} from '../eyes/eyes.component';
@Component({
selector: 'person',
directives: [
HairComponent,
EyesComponent
],
template: `
<hair [color]="'black'"></hair>
<eyes [color]="'brown'"></eyes>
`,
styles: `
hair { height: 150px; }
eyes { border-radius: 50%; }
`
})
export class Person {}
Import child components
Tell Person component about children components
Much better
data:image/s3,"s3://crabby-images/3f44b/3f44b9f2716a132a51e1dbe8f0b41319884d0706" alt=""
Slides: tiny.cc/angular2typescript
GitHub/Twitter: @JimTheDev
[square] html attributes?!?
data:image/s3,"s3://crabby-images/31872/31872f75f7e3cd71027f67a53731b3f5fe63aa14" alt=""
Slides: tiny.cc/angular2typescript
GitHub/Twitter: @JimTheDev
Data
flows down,
App
Person
Hair
Eyes
@Component({
// ...snip...
template: `
<hair [color]="'black'"></hair>
<eyes [color]="'brown'"></eyes>
`
})
...snip...
export class Person {}
event
data
(user input)
(visual output)
into
components
Slides: tiny.cc/angular2typescript
GitHub/Twitter: @JimTheDev
Handling user interaction
@Component({
// ... snip
template: `
<hair [color]="'black'"></hair>
<eyes [color]="'brown'" (blink)="blinked($event)">
</eyes>
`,
styles: `
hair { height: 150px; }
eyes { border-radius: 50%; }
`
})
export class Person {
blinked(eyeColor: string) {
console.log(eyeColor); // 'brown'
}
}
Interactions trigger events
Components may handle events from their children.
data:image/s3,"s3://crabby-images/7d4f3/7d4f314f4243d8483928488cb88546a0cb6641ea" alt=""
Slides: tiny.cc/angular2typescript
GitHub/Twitter: @JimTheDev
Events
flow up,
App
Person
Hair
Eyes
@Component({
//...snip...
template: `
<hair [color]="'black'"></hair>
<eyes [color]="'brown'"
(blink)=blinked($event)
></eyes>
`
})
...snip...
export class Person {}
event
data
Out
of components
Slides: tiny.cc/angular2typescript
GitHub/Twitter: @JimTheDev
Eyes should blink when clicked
import {Component} from 'angular2/angular2';
@Component({
selector: 'eyes',
outputs: ['blink'],
inputs: ['color'],
template: `
<eye (click)="blink(color)"></eye>
<eye (click)="blink(color)"></eye>
`
})
export class EyesComponent {}
Components emit
output events up to their parent components.
Detect a click, then call blink(), passing it color
But where do blink and color come from?
../eyes/eyes.component.ts
Components receive
inbound data passed down from their
parent.
data:image/s3,"s3://crabby-images/70fdc/70fdccf62feacb2df7edbf2ef9199251ecccbacb" alt=""
Slides: tiny.cc/angular2typescript
GitHub/Twitter: @JimTheDev
Play with Angular2 today
git clone https://github.com/pkozlowski-opensource/ng2-play
Get an example project
Set it up
npm i -g gulp
npm i
Run it
gulp play
See it
Browse to: http://localhost:9000
Slides: tiny.cc/angular2typescript
GitHub/Twitter: @JimTheDev
Thank you!
Learning
angular.io
github.com/angular-class/angular2-webpack-starter
github.com/angular-class/awesome-angular2
Questions?
github.com/pkozlowski-opensource/ng2-play
github.com/shprink/angular2-nobullshit-boilerplate
blog.thoughtram.io
Starter projects
Community
gitter.im/angular/angular
angularmn-slack.herokuapp.com
angularbuddies.com
JimTheDev on most sites
JimTheDev@gmail.com
Contact me
Jim Cummins
Getting started with Angular 2 and Typescript
By jimthedev
Getting started with Angular 2 and Typescript
- 6,606