the angular way 19 october 2013 gdańsk

30
The angular way Meet js summit Gdańsk 19 October 2013

Upload: marcin-wosinek

Post on 09-May-2015

524 views

Category:

Education


0 download

DESCRIPTION

There is a lot of positive buzz about angular in front end js framework community - directives, two-way bindings, 'by google'. There is as well some critic - it's bigger then backbone, unlike ember it does dirty checking. In this presentation we will take a look on 'the angular way' the set of practice that is necessary to know if we want to fairy judge angular. So we will take a look on: * TDD and unit tests with karma test runner * yo generators * grunt server * angular separation of concerns

TRANSCRIPT

Page 1: The angular way   19 october 2013 Gdańsk

The angular wayMeet js summit Gdańsk 19 October 2013

Page 2: The angular way   19 october 2013 Gdańsk

Who am I?● Marcin Wosinek● 5 years IT experience

- WebDev: Javascript- C# dev: UnitTests

● Currently js contractor in Roche in Poznan

Page 3: The angular way   19 october 2013 Gdańsk

You?

Page 4: The angular way   19 october 2013 Gdańsk

The buzz

Page 5: The angular way   19 october 2013 Gdańsk

Reality

Page 6: The angular way   19 october 2013 Gdańsk

Common pitfall

Page 7: The angular way   19 october 2013 Gdańsk
Page 8: The angular way   19 october 2013 Gdańsk
Page 9: The angular way   19 october 2013 Gdańsk

Angular strong points

● single page apps● forms● REST

Page 10: The angular way   19 october 2013 Gdańsk

Note

Page 11: The angular way   19 october 2013 Gdańsk

Angular’s domain

Page 12: The angular way   19 october 2013 Gdańsk

Angular’s domain NOT

Page 13: The angular way   19 october 2013 Gdańsk

Angular MV*

Model

Controller

ViewDirectives

Services

Page 14: The angular way   19 october 2013 Gdańsk

Concerns separationModel

Business logic

Controller

View logic

View

Declarative binding

Directives

DOM manip.

Services

Infrast. logic

Page 15: The angular way   19 october 2013 Gdańsk

Directives<ANY ng-show="{expression}">

<input ng-model="variable">

<ng-view> <any ng-view>

<ANY ng-class="{expression}">

<ANY ng-switch="expression"> <ANY ng-switch-when="matchValue1">...</ANY> <ANY ng-switch-when="matchValue2">...</ANY> ... <ANY ng-switch-default>...</ANY></ANY>

Page 16: The angular way   19 october 2013 Gdańsk

Modules - idea ● directives● services● controllers● filters

● directives● services● controllers● filters

Module A

Module B

START

file-a.js

file-b.js

Page 17: The angular way   19 october 2013 Gdańsk

Modules - splitting code

angular core

app core

user page admin page

angular ui

other lib

Page 18: The angular way   19 october 2013 Gdańsk

Testability

function HelloCtrl($scope, $window, $log) { $scope.message = 'Display me in view'; …

}

<div ng-repeat="project in projects | filter:search | orderBy:'name'"> </div>

<form ng-submit="addTodo()"> <input ng-model="todoText" /></form>

Page 19: The angular way   19 october 2013 Gdańsk

Keeping code testable

● DOM● services● $window● TDD FTW

Page 20: The angular way   19 october 2013 Gdańsk

Karma

Page 21: The angular way   19 october 2013 Gdańsk

Test frameworks

Page 22: The angular way   19 october 2013 Gdańsk

Yeoman

Page 23: The angular way   19 october 2013 Gdańsk

Grunt

Page 24: The angular way   19 october 2013 Gdańsk

Yo generators

Page 26: The angular way   19 october 2013 Gdańsk

AngularJs community

● fb.com/groups/angularjs.polska● ng-camp?

Page 27: The angular way   19 october 2013 Gdańsk

Summary

Page 28: The angular way   19 october 2013 Gdańsk

Questions

?

Page 29: The angular way   19 october 2013 Gdańsk

Contact

[email protected]● @MarcinWosinek● links, slides, notes and (hopefully) video:

http://bit.ly/ng-summit

Page 30: The angular way   19 october 2013 Gdańsk

Credits● Audience photo: http://www.flickr.com/photos/dougbelshaw/5604047370/● Bees photo: http://www.flickr.com/photos/theseanster93/4056815767/● hammer & screw: http://www.flickr.com/photos/justinbaeder/5317820857● ie: http://en.wikipedia.org/wiki/File:IE6SP3XPscreenshot.PNG● admin page: http://www.flickr.com/photos/juggernautco/10065981863/● shopin cart: http://www.flickr.com/photos/sswinehart/4415385405● wikipedia: http://upload.wikimedia.org/wikipedia/commons/8/87/WikipediaMainPage.png● games: http://www.flickr.com/photos/ian_d/30859899