Psal se rok 2009 … ano … 2009 ... Jak se tehdy tvořili webové aplikace ? ● pomocí server-side frameworků ● scriptování v jQuery Původním cílem AngularJS byl komerční framework ● náhrada stávajících view ● příklon k Single Page aplikacím
Serverside
VS
SPA
Serverside
VS
SPA
požadavek
1.požadavek
HTML - celá stránka
aplikace
požadavek
požadavek na data
HTML - konkrétní oblast
data
Šablonový systém v AngularJS <script src="https://…../angularjs/1.4.8/angular.min.js">
Dvoucestný databinding - jak s ním žít − angular výrazy vyhodnocuje pokud se něco mohlo změnit ○ musí být rychlé ○ nemáte pod kontrolou počet volání − počet watcherů < ~2500 + výměnou za to můžete pracovat přímo s JS objekty + ve většině případů vám ušetří čas a kód
Výborná dokumentace Početná komunita Ucelený framework Oddělení kódu a html Velké množství komponent a knihoven Testovatelnost ○ ○
ngMock protractor
Protractor - End to End testing for Angular ● nádstavba nad Seleniem ● přidává lokátory specifické pro Angular element(by.id('gobutton')); element(by.css('selected')); element(by.binding('user.name')); element(by.model('product.count')); element(by.repeater('product.count'));
AngularJS přerostl své odvětví
\
MOST POPULAR TECHNOLOGIES Stack Overflow - Developer Survey 2015
Kdy ho použít? Aplikace, aplikace aplikace ● informační systémy ● kalkulační nástroje ● … téměř cokoli za přihlášením Tam kde potřebujete vyměnit view a dokážete postavit REST API
Kdy ho nepoužít? Z důvodu SEO
Z důvodu výkonu
● klasické webové stránky
● vysoce dynamické aplikace ● “Excel”
(není náhrada jQuery) ● inzerce, e-shopy ?
Na co si dát pozor? ● množství a rychlost watcherů ● více aplikací na jedné stránce ● pište čistý kód ○ malé části kódu řešící jedem problém ● nespoléhejte na odstínění od javascriptu ○ prototypová dědičnost ○ promise ○ this ● dbejte na architekturu
Kdo ho používá
Youtube, PayPal, Mall, GoG, InvisionApp, Blue Origin, Lego Indiegogo, Docker, Best buy, NBA, Forbes, CNN, Weather... https://www.madewithangular.com
Angular 2 ● první zmínky 5/2014 ● Designed for the future ● 2.0.0-beta.6 (2016-02-11)
● bude to úplně jiný framework
Angular 2 - technologie ● psaný v TypeScriptu
● podpora pro ES5, ES6 i Dart ● používá RxJS (Reactive eXtension for JS) ○
a set of libraries to compose asynchronous and event-based programs using observable collections and Array#extras style composition in JS
○
funkcionální reaktivní programovní
○
developed by Microsoft Open Technologies, Inc.
Budoucnost - 1.x vs 2.x ● datum vydání 2.0 - x / 2016 ● upgrade? ○ použití 1.x komponent v 2.x (ngUpgrade) ○ použítí 2.x komponent v 1.x (ngForward) ○ spokojeně pokračovat na 1.x Má smysl na něj čekat? ● rozhodně stojí za to ho sledovat