Sunteți pe pagina 1din 35

Angular 2 Core

Angular 2 Core Igor Minar Tobias Bosch ng-europe 2014

AngularJS 1.3

<div ng-controller="SantaTodoController"> <input type="text" ng-model="newTodoTitle"> <button ng-click="addTodo()">+</button>

<tab-container> <tab-pane title="Tobias">

<div ng-repeat="todo in todosOf('tobias')"> <input type="checkbox" ng-model="todo.done"> {{todo.title}} <button ng-click="deleteTodo(todo)">

X

</button>

</div>

</tab-pane>

<button ng-click="deleteTodo(todo)"> X </button> </div> </tab-pane>

AngularJS 2.0

<div> <input type="text" [value]="newTodoTitle"> <button (click)="addTodo()">+</buton>

<tab-container> <tab-pane title="Good kids">

<div [ng-repeat|todo]="todosOf('good')"> <input type="checkbox" [checked]="todo.done"> {{todo.title}} <button (click)="deleteTodo(todo)">

X

</button>

</div>

</tab-pane>

<button (click)="deleteTodo(todo)"> X </button> </div> </tab-pane>

AngularJS 2.0

<div>

<input type="text" [value]="newTodoTitle"> [value]="newTodoTitle"

<button (click)="addTodo()">+</buton> (click)="addTodo()"

<tab-container> <tab-pane title="Good kids">

<div [ng-repeat|todo]="todosOf('good')"> [ng-repeat|todo]="todosOf('good')" <input type="checkbox"

[checked]="todo.done"> [checked]="todo.done"

{{todo.title}} {{todo.title}}

<button (click)="deleteTodo(todo)"> (click)="deleteTodo(todo)"

X

</button>

</div>

</tab-pane>

(click)="deleteTodo(todo)" X </button> </div> </tab-pane>

AngularJS 2.0

<div> <input type="text" [value]="newTodoTitle"> <button (click)="addTodo()">+</buton>

<tab-container> <tab-pane title="Good kids">

<div [ng-repeat|todo]="todosOf('good')"> <input type="checkbox" [checked]="todo.done"> {{todo.title}} <button (click)="deleteTodo(todo)">

X

</button>

</div>

</tab-pane>

<button (click)="deleteTodo(todo)"> X </button> </div> </tab-pane>

AngularJS 2.0

<div> <input type="text" [value]="newTodoTitle"> <button (click)="addTodo()">+</buton>

<tab-container> <tab-pane title="Good kids">

<div [ng-repeat|todo]="todosOf('good')"> <input type="checkbox"

[checked]="todo.done"> [checked]="todo.done" {{todo.title}}

<button (click)="deleteTodo(todo)">

X

</button>

</div>

</tab-pane>

<button (click)="deleteTodo(todo)"> X </button> </div> </tab-pane>

Databinding

<elm attr="

">

elm.property=

Databinding <elm attr=" "> elm.property=
Databinding <elm attr=" "> elm.property=
Databinding <elm attr=" "> elm.property=
Databinding <elm attr=" "> elm.property=
controllers 2009-2014
controllers
2009-2014
controllers 2009-2014

Directive Definition Object ("DDO")

myModule.directive('directiveName', function factory(injectables) { return { priority: 0, template: '<div></div>', // or // function(tElement, tAttrs) {

},

// or // templateUrl: 'directive.html', // or // function(tElement, tAttrs) {

transclude: false, restrict: 'A', templateNamespace: 'html', scope: false, controller: function($scope, $element, $attrs, $transclude, otherInjectables) {

},

},

controllerAs: 'stringAlias', require: 'siblingDirectiveName', // or // ['^parentDirectiveName', '? optionalDirectiveName', '?^optionalParent'], compile: function compile(tElement, tAttrs, transclude) { return { pre: function preLink(scope, iElement, iAttrs, controller) {

}

},

post: function postLink(scope, iElement, iAttrs, controller) {

 

}

// or // return function postLink(

) {

}

}, // or // link: { // pre: function preLink(scope, iElement, iAttrs, controller) { // post: function postLink(scope, iElement, iAttrs, controller) {

},

}

iElement, iAttrs, controller) { // post: function postLink(scope, iElement, iAttrs, controller) { }, } // }

// }

//

DDO 2009-2014
DDO
2009-2014
DDO 2009-2014

SantaTodoApp component

@ComponentDirective class SantaTodoApp { constructor() { this.newTodoTitle = '';

}

}

addTodo: function() {

removeTodo: function(todo) { todosOf: function(filter) {

}

}

}

= ''; } } addTodo: function() { removeTodo: function(todo) { todosOf: function(filter) { } } }

SantaTodoApp component

@ComponentDirective({ class SantaTodoApp {

})

}

@TemplateDirective({ class NgRepeat {

}

})

@DecoratorDirective({

}

class NgClass {

})

{ }) } @TemplateDirective({ class NgRepeat { } }) @DecoratorDirective({ } class NgClass { })

SantaTodoApp component

@ComponentDirective class SantaTodoApp { constructor() { this.newTodoTitle = '';

}

}

addTodo: function() {

removeTodo: function(todo) { todosOf: function(filter) {

}

}

}

= ''; } } addTodo: function() { removeTodo: function(todo) { todosOf: function(filter) { } } }
$scope 2009-2014
$scope
2009-2014
$scope 2009-2014

ng-repeat and $parent

Selected user: {{selectedUser.name}} <div ng-repeat="user in users" ng-click="selectedUser = user"> </div>

<div ng-repeat="user in users" ng-click="selectedUser = user"> </div>

ng-repeat and $parent

Selected user: {{selectedUser.name}} <div ng-repeat="user in users" ng-click="$parent.selectedUser = user"> </div>

<div ng-repeat="user in users" ng-click=" $parent. selectedUser = user"> </div>

Registering directives

@ComponentDirective({ directives: [TabContainer, TabPane, NgRepeat]

}) class SantaTodoApp { constructor() { this.newTodoTitle = '';

}

}

addTodo: function() {

removeTodo: function(todo) { todosOf: function(filter) {

}

}

}

= ''; } } addTodo: function() { removeTodo: function(todo) { todosOf: function(filter) { } } }

Dependency Injection

Dependency Injection
Dependency Injection

Defining services

class TodoStore { constructor(win:Window) { this.win = win;

}

add(todo) { // access this.win.localStorage

}

remove(todo) { todosOf(filter) {

}

}

}

{ this.win = win; } add(todo) { // access this.win.localStorage } remove(todo) { todosOf(filter) { }
angular .module 2009-2014
angular
.module
2009-2014
angular .module 2009-2014

Using services

import {TodoStore} from './store';

@ComponentDirective({ directives: [TabContainer, TabPane, NgRepeat]

}) class SantaTodoApp { constructor(store:TodoStore) {

}

}

directives: [TabContainer, TabPane, NgRepeat] }) class SantaTodoApp { constructor( store:TodoStore ) { } }

Directives and DI

<tab-pane title="Tobias"> New Macbook Pro Tesla Model X </tab-pane> <tab-pane title="Good
<tab-pane title="Tobias"> New Macbook Pro Tesla Model X </tab-pane> <tab-pane title="Good

<tab-pane title="Tobias">

New Macbook Pro Tesla Model X

</tab-pane>

New Macbook Pro Tesla Model X </tab-pane> <tab-pane title="Good kids">

<tab-pane title="Good kids">

</tab-pane>

title="Good kids"> </tab-pane> <tab-pane title="Bad kids">

<tab-pane title="Bad kids">

</tab-pane>

title="Good kids"> </tab-pane> <tab-pane title="Bad kids"> </tab-pane>
title="Good kids"> </tab-pane> <tab-pane title="Bad kids"> </tab-pane>
title="Good kids"> </tab-pane> <tab-pane title="Bad kids"> </tab-pane>

Directives and DI

class TabPane { constructor( tabContainer:TabContainer, element:HTMLElement {

)

}

}

class TabContainer { constructor(tabs:Query<TabPane>) { } }
class TabContainer {
constructor(tabs:Query<TabPane>) {
}
}

Performance

Measure Improve
Measure
Improve
Performance Measure Improve Analyze

Analyze

Performance Measure Improve Analyze

Measure

Measure

Macro optimizations

jqLite 2009-2014
jqLite
2009-2014

<div> <input type="text" [value]="newTodoTitle"> <button (click)="addTodo()">+</buton>

<tab-container> <tab-pane title="Good kids">

<div [ng-repeat|todo]="todosOf('good') <input type="checkbox" [checked]="todo.don {{todo.title}} <button (click)="deleteTo

X

</button>

</div>

</tab-pane>

{{todo.title}} <button (click)="deleteTo X </button> </div> </tab-pane>

Analyze

Analyze
Analyze

Analyze - Web Tracing Framework

Analyze - Web Tracing Framework

Summary

controllers

DDO

Summary controllers DDO generic binding syntax DI query mechanism benchpress WTF instrumentation $scope angular.module
generic binding syntax DI query mechanism benchpress WTF instrumentation
generic binding syntax
DI query mechanism
benchpress
WTF instrumentation

$scope

angular.module

jqLite

controllers DDO generic binding syntax DI query mechanism benchpress WTF instrumentation $scope angular.module jqLite