The Angular Platform
ng-fukuoka #1
@laco0416
about me
- Suguru Inatomi
- Angular Contributor
- ng-japan Organizer
- grad. from Kurume NCT
What's Angular?
data:image/s3,"s3://crabby-images/f60db/f60db7764ace7b5bcd2f8bb800c1b659c30e6681" alt=""
data:image/s3,"s3://crabby-images/b8ae2/b8ae231c20284990df506819f9b73d660f6a492c" alt=""
What Angular will do?
What's the Full-Stack?
Render Views
Data Model
View
Rendering
Data Model
View
@Component({
template: "<h1>{{title}}</h1>"
})
class MyComponent {
title = "Hello!";
}
<h1>Hello!</h1>
Watch model's change
Change Detection
data:image/s3,"s3://crabby-images/8dbb7/8dbb78d9ab308229a1eee45e0336ceb8df92cdf0" alt=""
data:image/s3,"s3://crabby-images/2d980/2d980d6a71989a162b0871c9282654132914483b" alt=""
Transit Views
Routing
data:image/s3,"s3://crabby-images/4fb91/4fb91815426f3fa08fe17c408377298762704d50" alt=""
Angular Router
- URL-Component Mapping
- Guard & Resolve
- Nesting
- Lazy-Loading
data:image/s3,"s3://crabby-images/d74c6/d74c62f838e86be91cb97701e4535986de826ec8" alt=""
Access to Server
AJAX
@Injectable()
export class HeroService {
constructor (private http: Http) {}
getHeroes (): Observable<Hero[]> {
return this.http.get("/api/heroes")
.map(resp => resp.json());
}
}
Http Service
Angular Http
- Wrap XHR/JSONP
- Return Observable
- Lazy-Execution
- Aborting
- Multi-Responses
@angular/http/client
- coming soon (4.3?)
-
Brand-new Http API
- Interceptor
- Progress Event
- Easy to test
Angular Animations
@Component({ animations: [ trigger("visibility", [ state("shown", style({ opacity: 1 })), state("hidden", style({ opacity: 0 })), transition("* => *", animate(".5s")) ]) ] }) class MyComponent() { ... }
data:image/s3,"s3://crabby-images/f60db/f60db7764ace7b5bcd2f8bb800c1b659c30e6681" alt=""
Side Projects
Angular CLI
- Scaffold Angular project
- Generate code
- Debug
- Test
- Lint
- Deploy
data:image/s3,"s3://crabby-images/fe45b/fe45b1e9273d4eaefa683ea6858eb6deaa165c2e" alt=""
Augury
- Chrome Extension for Angular Debugging
- Open Source
data:image/s3,"s3://crabby-images/346be/346be2d5f8ce9198dbbbc076e6f8180215fc77a7" alt=""
Angular Material
data:image/s3,"s3://crabby-images/11fa0/11fa0f61650864141f3ce64e6f8c8931f0f26bb4" alt=""
Angular Mobile Toolkit
data:image/s3,"s3://crabby-images/68531/68531d747b6a5726adeca822c6bf6b254ac5a588" alt=""
- Angular App => PWA
- @angular/app-shell
- @angular/service-worker
- "Automatic Progressive Web Apps"
- "Angular on Mobile"
data:image/s3,"s3://crabby-images/f60db/f60db7764ace7b5bcd2f8bb800c1b659c30e6681" alt=""
Angular Compiler
Compilation
Source
???
Application
data:image/s3,"s3://crabby-images/8d0eb/8d0ebcc4a71df31d1f97af62638e16f19e8a2dab" alt=""
AngularConnect 2016
AoT Compilation
- ng build --aot
- For Performance
- Bootstrap Time
- Download Size
-
For Debugging
-
Detect errors at build-step
-
AngularConnect 2016
data:image/s3,"s3://crabby-images/ad110/ad11097f321b5b58f89c786bb992fa4a89b3558a" alt=""
For templates
AngularConnect 2016
data:image/s3,"s3://crabby-images/bd55c/bd55cb364d8947c594ee407ccc972099d1a8684f" alt=""
For templates
Language Service
Angular Language Service
- VSCode Plugin (Official)
- WebStorm (Built-in)
data:image/s3,"s3://crabby-images/d4f87/d4f87c9898191b5fbd70ef277d0fa4328b35ea7f" alt=""
@angular/language-service
data:image/s3,"s3://crabby-images/f60db/f60db7764ace7b5bcd2f8bb800c1b659c30e6681" alt=""
Angular Universal
Server-Side Angular
@angular/platform-server
- Render Angular apps on Server
- renderModule / renderModuleFactory
- ≒ bootstrapModule / bootstrapModuleFactory
Angular Universal
- platform-server Wrappers
- For Express.js
- @nguniversal/express-engine
- For ASP.Net Core
- @nguniversal/aspnetcore-engine
- For Hapi (WIP)
- For Express.js
- universal.angular.io: DEPRECATED
data:image/s3,"s3://crabby-images/f60db/f60db7764ace7b5bcd2f8bb800c1b659c30e6681" alt=""
Dependency Injection
NgModule
Injectable
Token(Dependency)
Instance
Injector
Provider
NgModule
@NgModule({
providers: [
MyService,
{ provide: MyService, useClass: MyService },
{ provide: MyService, useValue: new MyService() },
{ provide: MyService, useFactory: () => new MyService() },
],
})
class AppModule {}
Token
Instance
Injectable
@Component({
selector: "my-component"
})
class MyComponent {
constructor(myService: MyService) {
}
}
Token
Instance
Injector
providers: [MyService]
new MyService()
{
MyService: myService
}
Injectable
constructor(
myService: MyService
)
Once at Bootstrap
data:image/s3,"s3://crabby-images/f60db/f60db7764ace7b5bcd2f8bb800c1b659c30e6681" alt=""
Missing piece?
Documentation
angular.io
data:image/s3,"s3://crabby-images/7cffc/7cffc4a54499fe25338c9601024ef254c39277cb" alt=""
angular.io as a docs
- Tutorial
- Fundamentals
- Techniques
- API References
angular.io as an app
- Built on Latest Angular
- Angular Material
- Angular Mobile Toolkit
- Angular PWA
- Source Code
- angular/angular: /aio
How to learn Angular?
- ES2015+
- TypeScript
- RxJS / Observables
- (Service Worker)
- (webpack)
- (Component Design)
Required Knowledges
Angular << Modern Web
Understand the Web
data:image/s3,"s3://crabby-images/499ed/499edcd61eb6fc44634498e23fdd717e86972465" alt=""
"The Web has moved.
Frameworks must move"
Keep Learning
Keep an eye
on changes
data:image/s3,"s3://crabby-images/2bc99/2bc9950616d35d5b7e4c6839e6f1ad8d00999021" alt=""
Watch CHANGELOG
Read Release Note
data:image/s3,"s3://crabby-images/0d993/0d993bf9f37126eb2c077452dfd4631c50bcb5e0" alt=""
Read Release Note
data:image/s3,"s3://crabby-images/f8d3d/f8d3df26e36f21f6bd38dec7db3c70d57e98d9df" alt=""
Join communities
data:image/s3,"s3://crabby-images/0bdf0/0bdf0bcf88a6c0645f95568baa8f2ee0352f0270" alt=""
Summary
- Angular Features
- View Rendering
- Routing
- AJAX
- And More
- Follow the style guide
- CLI is Best Practice ALWAYS
- Learn Modern Web First
Thanks
The Angular Platform
By Suguru Inatomi
The Angular Platform
ng-fukuoka #1
- 4,531