zum Inhaltsverzeichnis Kapitel 1 Liebe Leser! Wir wünschen Ihnen viel Spaß mit dieser Leseprobe!



Ähnliche Dokumente
zum Inhaltsverzeichnis zum Index Kapitel 1 Vielen Dank, dass Sie sich für ein ebook von entwickler.press entschieden haben!

Ein mobiler Electronic Program Guide

.htaccess HOWTO. zum Schutz von Dateien und Verzeichnissen mittels Passwortabfrage

Objektorientierte Programmierung für Anfänger am Beispiel PHP

Präsentation Von Laura Baake und Janina Schwemer

SANDBOXIE konfigurieren

Übung: Verwendung von Java-Threads

Scholz (Hrsg.) / Krämer / Schollmayer / Völcker. Android-Apps. Konzeption, Programmierung und Vermarktung

Diplomarbeit. Konzeption und Implementierung einer automatisierten Testumgebung. Thomas Wehrspann. 10. Dezember 2008

4D Server v12 64-bit Version BETA VERSION

2. ERSTELLEN VON APPS MIT DEM ADT PLUGIN VON ECLIPSE

Handbuch Fischertechnik-Einzelteiltabelle V3.7.3

Universal Dashboard auf ewon Alarmübersicht auf ewon eigener HTML Seite.

Version smarter mobile(zu finden unter Einstellungen, Siehe Bild) : Gerät/Typ(z.B. Panasonic Toughbook, Ipad Air, Handy Samsung S1):

Grundlagen von Python

Task: Nmap Skripte ausführen

TechNote. Produkt: TWINFAX 7.0 (ab CD_24), TWINFAX 6.0 Modul: SMTP, T611, R3 Kurzbeschreibung: Briefpapier- und Mailbodyunterstützung

Java Server Faces. Andy Bosch. Das Standard-Framework zum Aufbau webbasierter Anwendungen. An imprint of Pearson Education

Softwaretests in Visual Studio 2010 Ultimate Vergleich mit Java-Testwerkzeugen. Alexander Schunk Marcel Teuber Henry Trobisch

Es sollte die MS-DOS Eingabeaufforderung starten. Geben Sie nun den Befehl javac ein.

Installation der SAS Foundation Software auf Windows

4 Aufzählungen und Listen erstellen

.NET Code schützen. Projekt.NET. Version 1.0

Eine Anwendung mit InstantRails 1.7

Inhalt. 1 Einleitung AUTOMATISCHE DATENSICHERUNG AUF EINEN CLOUDSPEICHER

Leitfaden zur Einrichtung za-mail mit IMAP auf dem iphone

Hochschule Darmstadt Fachbereich Informatik

Virtueller Campus. Virtueller Campus Horw mit interaktiver Steuerung. HowTo: Externe Bibliotheken

Einrichten des IIS für VDF WebApp. Einrichten des IIS (Internet Information Server) zur Verwendung von Visual DataFlex Web Applications

HOWTO Update von MRG1 auf MRG2 bei gleichzeitigem Update auf Magento CE 1.4 / Magento EE 1.8

Der schnelle Weg zu Ihrer eigenen App

Microsoft SharePoint 2013 Designer

schnell und portofrei erhältlich bei beck-shop.de DIE FACHBUCHHANDLUNG mitp/bhv

Professionelle Seminare im Bereich MS-Office

Facebook I-Frame Tabs mit Papoo Plugin erstellen und verwalten

Robot Karol für Delphi

Über die Internetseite Hier werden unter Download/aktuelle Versionen die verschiedenen Module als zip-dateien bereitgestellt.

DOKUMENTATION VOGELZUCHT 2015 PLUS

VB.net Programmierung und Beispielprogramm für GSV

KURZANLEITUNG CLOUD OBJECT STORAGE

Datensicherung. Beschreibung der Datensicherung

Anleitung. Lesezugriff auf die App CHARLY Termine unter Android Stand:

OP-LOG

Patch Management mit

Menü auf zwei Module verteilt (Joomla 3.4.0)

Durchführung der Datenübernahme nach Reisekosten 2011

Appery.io Mobile Apps schnell und einfach entwickeln

Step by Step Webserver unter Windows Server von Christian Bartl

crm-now/ps Webforms Webdesigner Handbuch Erste Ausgabe

Jochen Bartlau. List & Label. schnell + kompakt

SCHRITT FÜR SCHRITT ZU IHRER VERSCHLÜSSELTEN

Anleitung BFV-Widget-Generator

Einfache und effiziente Zusammenarbeit in der Cloud. EASY-PM Office Add-Ins Handbuch

Ein mobiler Electronic Program Guide für Android

ELO Print&Archive so nutzen Sie es richtig

Installation und Inbetriebnahme von Microsoft Visual C Express

Gemeinsamer Bibliotheksverbund: Übertragung von Datenexporten für den Verbundkatalog Öffentlicher Bibliotheken

Albert HAYR Linux, IT and Open Source Expert and Solution Architect. Open Source professionell einsetzen

Prozessbewertung und -verbesserung nach ITIL im Kontext des betrieblichen Informationsmanagements. von Stephanie Wilke am

Einführung in PHP. (mit Aufgaben)

TTS - TinyTimeSystem. Unterrichtsprojekt BIBI

Logics App-Designer V3.1 Schnellstart

Liferay 6.2. Open Source IT-Dienstleister. Ein modernes Open Source Portal System. forwerts solutions GmbH, Gabriele Maas

Nie wieder eine Sitzung verpassen unser neuer Service für Sie!

Anleitung mtan (SMS-Authentisierung) mit SSLVPN.TG.CH

Qt-Projekte mit Visual Studio 2005

Einstellungen im Internet-Explorer (IE) (Stand 11/2013) für die Arbeit mit IOS2000 und DIALOG

GS-Programme 2015 Allgemeines Zentralupdate

mobilepoi 0.91 Demo Version Anleitung Das Software Studio Christian Efinger Erstellt am 21. Oktober 2005

Upgrade auf die Standalone Editionen von Acronis Backup & Recovery 10. Technische Informationen (White Paper)

Java Entwicklung für Embedded Devices Best & Worst Practices!

Wordpress: Blogbeiträge richtig löschen, archivieren und weiterleiten

Agile Vorgehensmodelle in der Softwareentwicklung: Scrum

Installationsanleitung für Magento-Module

Adminer: Installationsanleitung

COSA. Portal Client Installation JAVA J2SE / JRE Version 1.4.2_09, Stand Copyright

Guide DynDNS und Portforwarding

SSI WHITE PAPER Design einer mobilen App in wenigen Stunden

Serviceanweisung Austausch Globalsign Ausstellerzertifikate

Eine App, viele Plattformen

Ablaufbeschreibung für das neu Aufsetzen von Firebird und Interbase Datenbanken mit der IBOConsole

Online Newsletter III

Matrix42. Use Case - Sicherung und Rücksicherung persönlicher Einstellungen über Personal Backup. Version September

PHPNuke Quick & Dirty

PHP Kurs Online Kurs Analysten Programmierer Web PHP

Aufklappelemente anlegen

Benutzerhandbuch. Leitfaden zur Benutzung der Anwendung für sicheren Dateitransfer.

Lokale Installation von DotNetNuke 4 ohne IIS

:: Anleitung Hosting Server 1cloud.ch ::

Persönliches Adressbuch

SEPA-Anleitung zum Release 3.09

Clientkonfiguration für Hosted Exchange 2010

Anleitung zum erfassen von Last Minute Angeboten und Stellenangebote

25 Import der Beispiele

INFOnline SZM-Checker Ergänzung zum Manual

easytermin App easysolution GmbH 1

APPS für ios 9 professionell entwickeln

Anleitung zum ebanking KOMPLETT - Computercheck So aktualisieren Sie Ihr Microsoft-Betriebssystem

Transkript:

Liebe Leser! Wir wünschen Ihnen viel Spaß mit dieser Leseprobe! Mehr ebooks und alle Informationen zu unserem Verlagsprogramm finden Sie unter: www.entwickler-press.de Ihr entwickler.press-team zum Inhaltsverzeichnis Kapitel 1 Mit den Pfeiltasten können Sie durch das Dokument navigieren, mit der ESC-Taste beenden Sie den Vollbildmodus.

Tobias Bosch, Stefan Scheidt, Torsten Winterberg Mobile Web-Apps mit JavaScript Leitfaden für die professionelle Entwicklung

Tobias Bosch, Stefan Scheidt, Torsten Winterberg Mobile Web-Apps mit JavaScript ISBN: 978-3-86802-273-5 2012 entwickler.press Ein Imprint der Software & Support Media GmbH Bibliografische Information Der Deutschen Bibliothek Die Deutsche Bibliothek verzeichnet diese Publikation in der Deutschen Nationalbibliografie; detaillierte bibliografische Daten sind im Internet über http://dnb.ddb.de abrufbar. Ihr Kontakt zum Verlag und Lektorat: Software & Support Media GmbH entwickler.press Darmstädter Landstraße 108 60598 Frankfurt am Main Tel.: +49 (0)69 630089-0 Fax: +49 (0)69 630089-89 lektorat@entwickler-press.de http://www.entwickler-press.de Lektorat: Sebastian Burkart Korrektorat: Lisa Pychlau Satz: Laura Acker Alle Rechte, auch für Übersetzungen, sind vorbehalten. Reproduktion jeglicher Art (Fotokopie, Nachdruck, Mikrofilm, Erfassung auf elektronischen Datenträgern oder anderen Verfahren) nur mit schriftlicher Genehmigung des Verlags. Jegliche Haftung für die Richtigkeit des gesamten Werks kann, trotz sorgfältiger Prüfung durch Autor und Verlag, nicht übernommen werden. Die im Buch genannten Produkte, Warenzeichen und Firmennamen sind in der Regel durch deren Inhaber geschützt.

Inhaltsverzeichnis 1 Einleitung 11 1.1 Warum dieses Buch? 11 1.2 Warum mobile Webapplikationen? 12 1.3 Warum JavaScript? 14 1.4 Single Page Web-Apps 15 1.5 Entwicklungsprozess 16 1.6 Ziel des Buchs 17 1.7 Zielgruppe dieses Buchs 18 1.8 Vorstellung des durchgehenden Use Case 18 1.8.1 Das Beispielunternehmen RYLC 19 1.8.2 Fachlichkeit der Beispielanwendung 20 1.8.3 Architektur der Beispielanwendung 23 1.8.4 Codebeispiele online 24 1.9 Kapitelübersicht 24 2 JavaScript-Grundlagen 29 2.1 Objekte und Objektliterale 29 2.2 Funktionen 30 2.2.1 Codeblöcke 31 2.2.2 Callbacks 31 2.2.3 Methoden 32 2.2.4 Sofort ausgeführte Funktionsausdrücke 33 2.3 Namespaces 34 2.4 Module 34 Mobile Web-Apps mit JavaScript 5

Inhaltsverzeichnis 3 Projekt-Setup 37 3.1 Maven 39 3.1.1 Convention over Configuration 39 3.1.2 Das Project Object Model 41 3.1.3 Build Lifecycle 42 3.1.4 Plug-ins 43 3.2 Ant 46 3.3 Entwicklungsumgebungen 49 4 Testen 51 4.1 Testen von und mit JavaScript 53 4.2 Unit Tests mit Jasmine 55 4.3 Der Jasmine Spec Runner 59 4.4 Jasmine Spies 62 4.5 Asynchrone Tests 64 4.6 Automatische Testausführung 65 4.7 Integration in das Projekt-Setup 68 4.8 Fazit 71 5 Oberflächenkomponenten 73 5.1 Beispiele für Komponentenbibliotheken 76 5.1.1 jquery Mobile 77 5.1.2 Sencha Touch 80 5.2 jquery Mobile 83 5.2.1 Gerüst einer jquery-mobile-html-seite 84 5.2.2 jquery Mobile Pages 85 5.2.3 Gestaltung des Content-Bereichs 88 6

Inhaltsverzeichnis 5.3 Oberflächentests 91 5.3.1 Jasmine UI 92 5.3.2 Fortgeschrittene Konzepte 98 6 Data Binding 103 6.1 Manuelles Data Binding 105 6.2 Data Binding mit Angular 108 6.2.1 Scopes und Controller 109 6.2.2 Templates 114 6.2.3 Integration von Angular und jquery Mobile 118 6.3 Angular-Module 119 6.4 Weiterführende Konzepte 121 6.4.1 Erweiterungen der Controller-Logik 122 6.4.2 Shared Controller 123 6.4.3 Repeater Scopes 126 6.4.4 Filter 128 6.5 Zusammenfassung 128 7 Backend-Kommunikation 129 7.1 Dependency Injection mit Angular 130 7.2 Angular Promises 134 7.3 Zugriff auf das Backend 141 7.4 Tests für Backend-Kommunikation 147 7.5 Zusammenfassung 150 8 Die fertige Web-App 151 8.1 Architektur im Überblick 151 8.2 Shared Controller 154 8.3 Wait-Dialog 156 Mobile Web-Apps mit JavaScript 7

Inhaltsverzeichnis 8.4 Prefetching 159 8.5 Mehrseitige Wizard-artige Dialoge 162 8.6 Weitere Eventtypen 163 8.7 Nachladen bei großen Datenmengen 164 8.8 Kontrolle der Browser-History 165 9 Modularisierung und Build 169 9.1 Modularisierung von HTML 170 9.2 Modularisierung von CSS 173 9.3 Modularisierung von JavaScript 175 9.3.1 Moduldefinition 176 9.3.2 Zusammenspiel mit AngularJS 182 9.3.3 Zusammenspiel mit automatisierten Tests 183 9.3.4 Build und Optimierung 185 9.4 Das Ergebnis 188 9.5 Die App in Betrieb nehmen 189 10 Hybride Apps 191 10.1 PhoneGap 191 10.2 PhoneGap Build 193 10.3 Lokaler Build 195 10.4 Eigene Plug-ins 197 10.5 JavaScript-Entwicklung mit PhoneGap-Proxy 201 10.6 Das Backend in Betrieb nehmen 206 10.7 Zusammenfassung 207 Stichwortverzeichnis 209 8

Danksagung Wir bedanken uns herzlich bei der Firma OPITZ CONSULTING GmbH, ohne deren Unterstützung dieses Buch nicht zustande gekommen wäre. Bei unseren Familien möchten wir uns dafür bedanken, dass wir so manches Mal der Arbeit an dem Buch den Vorrang vor unserem Familienleben gegeben haben. Für ihre inhaltlichen Beiträge zum Buch bedanken wir uns bei Herrn Farid Zaid und Herrn Jörg Bredlau. Frau Jennifer Zimmermann danken wir für die Erstellung der wunderbaren Abbildungen. Ein persönlicher Dank von Stefan Scheidt geht an Herrn Dr. Dirk Koller für die Inspiration durch sein Buch iphone-apps entwickeln. Zum Schluss bedanken wir uns herzlich bei entwickler.press für die Unterstützung bei der Erstellung und Veröffentlichung des Buchs. Das Autorenteam Tobias Bosch, Stefan Scheidt und Torsten Winterberg

1 Einleitung 1.1 Warum dieses Buch? Sie nehmen dieses Buch in die Hand und fragen sich vielleicht, was das Besondere an diesem Werk sein mag. Warum macht sich jemand die Mühe, eine weitere Publikation zur langen Liste der schon existierenden JavaScript-Bücher hinzuzufügen? Nun, die Antwort ist einfach: Wir hatten gar nicht vor, ein Buch zu schreiben. Als wir damals begonnen haben, uns mit der Entwicklung von mobilen Webanwendungen zu beschäftigen, haben wir viel Recherche betrieben, die uns die Einarbeitung leichter machen sollte. Dabei hat sich jedoch herausgestellt, dass wir scheinbar eine seltsame Zielgruppe darstellen, die (bisher) nicht gut in der Literatur adressiert wird. Wir haben unseren Hintergrund in der Entwicklung von Enterprise-Java-Anwendungen und sind es gewohnt, kleinere bis sehr große Projekte professionell abzuwickeln. Dabei werden wir unterstützt von agilen, flexiblen Softwareentwicklungsprozessen, wir entwickeln im Geiste des Software-Craftmenship und legen sehr viel Wert auf testgetriebene Ansätze. In der Literatur haben wir viel Hilfe gefunden in Form von Büchern, die Ausschnitte beleuchten, etwa neue HTML5-Features, AJAX-Backend-Kommunikation, Sprachfeatures von JavaScript oder Zusammenfassungen sinnvoller Entwurfsmuster. Unser Wunsch nach einer kompletten, durchgehenden Anleitung, wie man professionell auf hohem Niveau nun Webanwendungen schreiben kann, die auf mobilen Endgeräten laufen, ging nicht in Erfüllung. Also haben wir uns dem Thema ohne eine solche Anleitung genähert, was teilweise recht schmerzhaft war. Daher beschlossen wir Mitte 2011, unsere gewonnenen Erkenntnisse in Form eines Workshops weiterzugeben. Diesen Workshop mit dem Titel Mobile JavaScript-Web-Apps professionell entwickeln hielten wir zum ersten Mal auf der W-JAX- Mobile Web-Apps mit JavaScript 11

1 Einleitung Konferenz in München im November 2011 und dann diverse weitere Male, z. B. auf der MobileTech Conference Spring 2012 und auch der JAX 2012 mit sehr gutem Feedback. Dieses Buch basiert nun auf dieser Workshopserie und liefert den Leitfaden zur professionellen Entwicklung mobiler JavaScript-Web-Apps, den wir lange Zeit selbst so schmerzlich vermisst haben. 1.2 Warum mobile Webapplikationen? Der wirkliche Hype um mobile Lösungen wurde wohl unstrittig ca. 2008 durch die Markteinführung von Apples iphone ausgelöst. Ausgestattet mit einem exzellenten App-Konzept konnten viele spannende Anwendungen und Funktionalitäten einfach nachgerüstet werden. Das Konzept des App Store begann sich zu etablieren. Zwei Jahre später drängten dann die Android-basierten Smartphones auf den Markt, einhergehend mit einer großen Vielfalt an unterschiedlichen Geräten und Displaygrößen, die heute abgerundet werden von einem Angebot an Tablet-PCs, ebenfalls mit sehr unterschiedlichen Auflösungen und Formfaktoren. Wie groß die Rolle von ehemals etablierten Plattformen wie RIM/Black- Berry und Microsoft/Nokia sein wird, lässt sich heute nur spekulieren. Diese Situation macht die Erstellung von nativen Apps mit einer breiten Plattformunterstützung sehr aufwändig, da Code nicht einfach wiederverwendet werden kann. Jede Plattform bringt ihre eigenen Sprachen, Entwicklungswerkzeuge und Eigenarten mit. Was kann man also tun, um den Entwicklungsaufwand einzugrenzen? Für die Frage, welche Plattformen gerade hip sind und in jedem Fall bedient werden wollen, lassen sich zahlreiche Statistiken der einschlägigen Analysten auftreiben, die sich mehr oder weniger deutlich voneinander unterscheiden. Anfang 2012 werden hier typischerweise ios und Android genannt. Kann man die Plattformbreite derart einschränken, dann muss man sich lediglich darum kümmern, die nativen Apps für 12

Warum mobile Webapplikationen? diese beiden Plattformen mit ihren unterschiedlichen Formfaktoren zu erstellen. Dies erscheint vom Aufwand her tragbar. Hat man aber eine größere Gerätevielfalt abzudecken, kommt schnell der Wunsch nach einer Cross-Plattform-Technologie auf, um eine App nur einmal entwickeln und dann mit keinen oder nur minimalen Anpassungen überall verwenden zu können. Hierzu bieten sich natürlich die Browser an und das mittlerweile allgegenwärtige HTML5, das antritt, das Cross-Plattform-Versprechen einzulösen. Vielerorts wird nun behauptet, dass mobile Web-Apps mit HTML5 von nativen Anwendungen nicht zu unterscheiden seien und daher immer gleichwertig zu den nativen Apps zu betrachten seien. Aus unserer Sicht ist dies keineswegs der Fall. Native Apps sind, was das Bedienungs- Feeling angeht, immer sexier als die Pendants mit HTML5. Wenn der Erfolg einer App davon abhängt, sich gegen viele gleichartige Apps durchzusetzen und möglichst oft in einem App Store heruntergeladen zu werden, meist in typischen B2C-Szenarien, wird man um eine native Implementierung nicht herumkommen. Für viele Einsatzszenarien sind die HTML5-Web-Apps aber schlicht gut genug, beispielsweise dann, wenn es für die umzusetzende Aufgabe keine alternative App geben kann, wenn es nicht darauf ankommt, dass sich die App 100 % nativ und sexy anfühlt, typischerweise dann eher im B2B-Umfeld. Hier kann sich dann der Cross-Plattform-Vorteil durchsetzen und eine möglichst große Bandbreite an Plattformen (z. B. ios, Android, Windows Phone und BlackBerry) abgedeckt werden. Nicht zu unterschätzen ist auch der Vorteil des HTML-Ansatzes, wenn es um schnelle Updates der Anwendung geht. Da der Code jeweils vom Server neu geladen wird, kommen Änderungen sofort zum Tragen, wohingegen Apps im App Store mitunter aufgrund der komplexen Freigabeprozesse längere Updatezyklen haben. Selbstverständlich sind hier auch Mittelwege denkbar, bei denen native Apps HTML-Code nachladen und diesen in dynamischeren Bereichen sinnvoll anzeigen (Stichwort Hybrid-Apps). Mobile Web-Apps mit JavaScript 13

1 Einleitung Ein weiterer guter Grund für die Entscheidung für die Web-App liegt darin begründet, dass wir einen starken Hintergrund in der Enterprise- Java-Welt haben, uns in der Implementierung klassischer Webanwendungen sehr gut auskennen und unsere Kenntnisse sehr schnell auf die Entwicklung mobiler Webanwendungen ausdehnen können. 1.3 Warum JavaScript? JavaScript erlebt gerade einen regelrechten Aufschwung. In der Vergangenheit wurde die Sprache etwas belächelt, weil sie im Wesentlichen zum Aufhübschen von Webseiten verwendet, aber nicht als echte Sprache für professionelle Anwendungsentwicklung gesehen wurde. Mit der enormen Ausbreitungsgeschwindigkeit von HTML5 dreht sich dieser Trend: JavaScript ist auf dem Weg, sich als Sprache zur Anwendungsentwicklung und Oberflächenprogrammierung zu etablieren. Man kann durchaus behaupten, dass JavaScript für die Webentwicklung das ist, was Java für Enterprise Computing im Backend bedeutet. JavaScript enthält viele sehr moderne Eigenschaften für eine 15 Jahre alte Programmiersprache. Wenn man die Sprache richtig einsetzt, kann sie sehr gut mit aktuellen Vertretern wie Groovy oder Ruby mithalten. Sie hat als dynamisch typisierte, objektorientierte Skriptsprache mit prototypbasierter Vererbung viele für den Java-gewohnten Entwickler ungewohnte Eigenschaften. Es braucht seine Zeit, sich daran zu gewöhnen und zu lernen, idiomatisch gutes JavaScript zu schreiben. Je früher man sich damit auseinander setzt, desto besser. Auch auf dem Server hält JavaScript mit Laufzeitumgebungen wie Node.js Einzug und platziert sich dort als sehr valide Lösung für bestimmte Problemkategorien, beispielsweise Anwendungen, die eine große Anzahl konkurrierender Zugriffe auf langsame Ressourcen unterstützen müssen. Es gibt zwar zunehmend mehr Werkzeuge, die das Programmieren in JavaScript vor dem Entwickler verbergen, wie z. B. Google Web Toolkit, CoffeeScript, ClojureScript oder auch neue Sprachansätze, wie Google Dart. Dennoch ist eine fundierte Kenntnis der Grundlagen unentbehrlich. 14

Single Page Web-Apps 1.4 Single Page Web-Apps Die innere Architektur der Web-Apps ändert sich stark. Man entfernt sich von dem gängigen Muster klassischer Webanwendungen, die dadurch geprägt sind, dass die Seitennavigation in der Regel durch ein MVC-Muster umgesetzt wird, was den Pageflow Controller auf dem Server ansiedelt. Die Interaktion mit einer Webseite löst einen Request gegen den Webserver aus, hier ermittelt der Pageflow Controller, welche Seite als Nächstes angezeigt werden soll und der Server schickt diese Seite als Response an den Browser zurück. Bei Web-Apps hingegen wird der Client intelligenter. Man verlagert den Pageflow Controller in der Regel auf den Client, meist in JavaScript realisiert. Hier spricht man dann von den so genannten Single Page Web-Apps. Dies liegt darin begründet, dass beim einmaligen Laden einer HTML-Seite gleich die ganze Web-App geladen wird, also eine einzige HTML-Seite, von der aber nur ein Teil angezeigt wird. Soll eine andere Seite angezeigt werden, so blendet der Pageflow Controller auf Clientseite lediglich einen anderen Bereich der schon geladenen Seite ein. Auf diese Weise wird der Request- Response-Zyklus zum Server und zurück vermieden. Dieser tritt lediglich beim Aufruf von Services auf, die per SOAP oder aber meist REST angesprochen werden. Hier leistet beispielsweise ein Enterprise Service Bus (ESB) gute Dienste bei der Protokollkonvertierung, wenn das bestehende Service-Backend nur SOAP spricht, im Frontend aber REST zum Einsatz kommen soll. Im Ergebnis handelt es sich bei Single Page Web-Apps also mehr um Clientapplikationen im Sinne der Client-Server-Programmierung als um Webapplikationen im Sinne von serverseitig generierten Webseiten. Mobile Webapplikationen, die auf diese Weise entwickelt wurden, integrieren sich hervorragend in Gesamtarchitekturen, bei denen das Backend über ein RESTful API angesprochen werden kann. Optimal für das Zusammenspiel ist eine Kommunikation auf Basis der JavaScript Object Notation (JSON). Weitere Vorteile dieser Applikationsarchitektur sind die potenziellen Offlinefähigkeit der Clients und die Möglichkeit, Mobile Web-Apps mit JavaScript 15

1 Einleitung diese Applikationen mit Werkzeugen wie beispielsweise PhoneGap in native Applikationen zu verpacken, die dann einerseits vollen Zugriff auf die Hardwarefunktionalitäten der Ausführungsumgebung haben, als auch wie native Apps durch die entsprechenden Distributionskanäle der Plattformen ( App Stores ) verteilt werden können. Auch die Desktopwebanwendungen werden von diesem neuen Architekturmuster profitieren. 1.5 Entwicklungsprozess Um eine effiziente und qualitativ hochwertige Entwicklung sicherzustellen, verwenden wir bei der Entwicklung erprobte Open-Source-Software-Komponenten wie beispielsweise jquery Mobile als Komponentenbibliothek für die Gestaltung der Benutzeroberfläche oder AngularJS als JavaScript-Framework für die Entwicklung der JavaScript-basierten Clientschicht. Durch den Einsatz testgetriebener Entwicklung stellen wir die Qualität und kontinuierliche Auslieferungsfähigkeit der Ergebnisse unserer Entwicklungsiterationen sicher. Wir nutzen dieses Vorgehen sowohl bei einzelnen Komponenten durch Unit Tests als auch bei der Entwicklung von Applikationsfunktionen durch automatisierte Akzeptanztests. Auch hier verwenden wir erprobte und weit verbreitete Werkzeuge wie beispielsweise das Behaviour-Driven-Design-Framework Jasmine und erweitern diese bei Bedarf um benötigte Komponenten (siehe das Git- Hub Projekt Jasmine UI ). Die Integration dieser Entwicklungspraktiken in einen Continuous-Integration-Prozess mit kontinuierlichen Projekt-Builds erlaubt eine feingranulare Überwachung des Zustands der Entwicklung und kurzfristige Reaktion auf Fehler und Probleme. Darüber hinaus ist damit die Einbettung der Entwicklung in eine agile, iterative Projektvorgehensweise möglich, welche die Bereitstellung auslieferbarer Ergebnisse in kurzen Zeitabständen erfordert. 16

1.6 Ziel des Buchs Ziel des Buchs Wir möchten hier keine Diskussion pro oder kontra native Entwicklung vs. Entwicklung von mobilen Web-Apps führen. Wie oben beschrieben, gibt es gute Argumente für beide Vorgehensweisen. Wir gehen in diesem Buch von der Annahme aus, dass Sie sich bewusst für den Weg der mobilen Web-Apps entschieden haben, und lernen möchten, wie man gutes Softwaredesign für eine JavaScript-Web-App implementiert. Ja, richtig. Vieles ist nicht rein Mobile-spezifisch, sondern gilt auch für nicht-mobile JavaScript-Web-Apps. Sie lernen also vielleicht mehr, als Sie eigentlich gedacht hatten... Unser Ziel ist es nicht, aufs letzte Bit zu zeigen, was in HTML5 alles geht, also z. B. Media Queries, UI-Design, neue Tags, etc., dafür gibt es mittlerweile reichlich gute Literatur am Markt. Unser Anspruch ist es vielmehr, Ihnen testgetriebene Entwicklung für JavaScript näherzubringen, Sie in die Lage zu versetzen, wartbaren Code, Clean Code, zu schreiben und die Gesamtzusammenhänge zu verdeutlichen. Wir werden keine Featureschlacht vorstellen, sondern einen kompletten End2End-Durchlauf über alle relevanten Implementierungsbestandteile einer mobilen Webapplikation mit Backend-Anbindung an einem einzigen, durchgängigen Beispiel beschreiben. Kurz: Wir möchten Ihnen die Anleitung zum Einstieg in die Programmierung mobiler Web-Apps zur Verfügung stellen, die uns damals gefehlt hat, und Sie schnell in die Lage versetzen, architektonisch saubere, qualitativ hochwertige und dauerhaft stabile Web-Apps zu programmieren. Mobile Web-Apps mit JavaScript 17

1 Einleitung 1.7 Zielgruppe dieses Buchs Wir adressieren mit diesem Buch all diejenigen, die mobile JavaScript- Web-Apps professionell entwickeln möchten und sich dabei auch für innere Werte wie Wartbarkeit, Erweiterbarkeit und Testbarkeit interessieren. Wir sprechen im Wesentlichen die Zielgruppe der klassischen Java-Webentwickler an, da diese vermutlich alle aufgrund der schnell wachsenden Verbreitungszahlen von Smartphones und Tablets, kurzbis mittelfristig Grundkenntnisse erlernen und erste Schritte mit dem neuen Paradigma der Web-Apps durchlaufen müssen. Aber auch für die Entwickler klassischer, nicht notwendigerweise mit Java erstellter Webanwendungen ist das Buch gedacht, da Java-Kenntnisse auf Frontend-Seite natürlich nicht nötig sind und hier somit zwei Welten zusammenwachsen. Wenn Sie also generell vor der Herausforderung stehen, reichhaltige JavaScript-Web-Apps im Enterprise-Umfeld schreiben zu wollen, dann lohnt es sich, nun weiterzulesen. 1.8 Vorstellung des durchgehenden Use Case Das in diesem Buch verwendete Praxisbeispiel basiert auf dem bekannten Rent Your Legacy Car (RYLC) Showcase. Dieser wurde im Java Magazin in einer 14-teiligen Reihe (11.2008 bis 12.2009) verwendet, um SOA-Prinzipien zu verdeutlichen und anschließend im Sonderheft SOA Spezial zusammengefasst. In diesem Buch erweitern wir diesen Showcase um einen mobilen Vertriebskanal mit der Möglichkeit einer mobilen Autoanmietung. 18

Vorstellung des durchgehenden Use Case 1.8.1 Das Beispielunternehmen RYLC Rent Your Legacy Car (RYLC) ist ein Autoverleih-Unternehmen mit der Vision, in den nächsten Jahren zu den drei umsatzstärksten Unternehmen des Car Rental Segments zu gehören. Seit Längerem ist das RYLC- Management mehr und mehr gezwungen, sich mit einer aggressiveren Marktsituation auseinandersetzen zu müssen. In den letzten Jahren hat RYLC immer wieder Marktanteile verloren. Die Konkurrenz konnte neue Produkte und besseren Service schneller bieten, während RYLC aufgrund von IT-Integrations-problemen nicht nachkam. Zur Adressierung dieser Hauptschmerzpunkte erarbeitet die Fachseite die folgenden Anforderungen: Als Unique Selling Point (USP) soll eine neue, hochqualitative Dienstleistung eingeführt werden, die RYLC deutlich vom Mitbewerb differenziert. Firmen- als auch Privatkunden bekommen einen Mietwagen innerhalb einer Stunde garantiert zum gewünschten Einsatzort geliefert, der ohne Mehrkosten am Reiseziel wieder abgeholt wird. Falls der Kunde das Auto an einer Basisstelle selbst abholt oder zurückbringt, erhält er einen Rabatt. Bisher war das Unternehmen ausschließlich über den Vertriebskanal DirektSales an zentralen Knotenpunkten wie Flughafen, Hauptbahnhof und Schiffshafen vertreten. In Zukunft werden weitere Vertriebskanäle wie das Smartphone, das Internet und SMS eingeführt. Die garantierte Qualität von Leihwagen soll durch bessere Kontrolle des Fahrzeugzustands (Sauberkeit, Wartungsintervall) zur Verbesserung der Kundenzufriedenheit gesteigert werden. Der Kontext in diesem Buch: Erweiterung der Vertriebskanäle um eine Möglichkeit zur Autoanmietung von unterwegs. Mobile Web-Apps mit JavaScript 19

1 Einleitung 1.8.2 Fachlichkeit der Beispielanwendung In diesem Buch werden wir sukzessive insgesamt vier RYLC Use Cases entwickeln: Login/Logout Benutzerprofil des angemeldeten Benutzers anzeigen Leihwagen-Buchungshistorie des angemeldeten Benutzers anzeigen Durchführen einer Leihwagen-Onlinebuchung von unterwegs Am Ende des Buchs werden Sie die vollständig funktionsfähige RYLC- Web-App auf Ihrem eigenen Smartphone oder Tablet ausprobieren können. Auf diesem Weg werden wir alle relevanten Schritte erläutern, wie ein solches Ergebnis professionell erzeugt werden kann. Wie bereits beschrieben, legen wir den Fokus nicht auf eine vollständige Beschreibung der einzelnen Themen, sondern auf eine möglichst gute Erläuterung des Zusammenspiels aller für diesen Showcase nötigen Einzelaspekte. Abbildung 1.1: RYLC-Login mit falschem Passwort 20

Vorstellung des durchgehenden Use Case Abbildung 1.2: RYLC-Login mit korrektem Passwort Abbildung 1.3: RYLC-Logout Mobile Web-Apps mit JavaScript 21

1 Einleitung Abbildung 1.4: RYLC-Benutzerprofil Abbildung 1.5: RYLC-Buchungshistorie 22

Vorstellung des durchgehenden Use Case Abbildung 1.6: RYLC Neue Buchung durchführen 1.8.3 Architektur der Beispielanwendung Wir legen im Sinne von brauchbaren Beispielen viel Wert darauf, ein echtes Backend für unsere RYLC-Web-App zu verwenden. Um nicht zu weit abzudriften, stellen wir dieses Backend as is zur Verfügung, gehen aber nicht auf Details ein. In aller Kürze: Es handelt sich um ein Spring-basiertes Backend, das die notwendigen Services über das Web- Service-Framework Apache CXF über ein REST-API zur Verfügung stellt. Als Ausführungsumgebung dient ein Jetty-Container, der sowohl die nötigen Artefakte für die mobile Web-App ausliefert (HTML, Java- Script, CSS), als auch das Backend mit seinem REST-API bereitstellt, wie in Abbildung 1.7 verdeutlicht. Wir verwenden also hier ein Co-located Deployment, das für Produktionsszenarien leicht auf ein verteiltes Deployment angepasst werden kann. Mobile Web-Apps mit JavaScript 23

1 Einleitung Abbildung 1.7: RYLC-Architektur 1.8.4 Codebeispiele online Die Webseite zum Buch beinhaltet den Beispielcode, Updates, weitere Informationen sowie die Links zu den verwendeten Technologien und Frameworks, sowie zum GitHub Repository: www.opitz-consulting.com/ go_javascriptbuch. 1.9 Kapitelübersicht Dieses Buch beschreibt die sukzessive Erstellung der oben beschriebenen Anwendungsfälle für die mobile RYLC-Web-App. Der Aufbau erfolgt didaktisch entlang der Grundsätze der testgetriebenen Entwicklung. Nachdem die Grundlagen gelegt sind, werden beispielhaft die Kapitelübergänge von Kapitel 5 nach 6 und von Kapitel 6 nach 7 jeweils über rote Tests motiviert, die dann entsprechend grün gemacht werden. 24

Kapitelübersicht Kapitel 1, Einleitung Hier werden die Motivationen für das Buch sowie für mobile Web-Apps inklusive unserer Zielsetzungen und der durchgehenden Beispielanwendung beschrieben. Kapitel 2, JavaScript-Grundlagen Dieses Kapitel vermittelt kein vollständiges Grundlagenwissen zu JavaScript. Vielmehr werden die wichtigsten Aspekte herausgegriffen, die für das Nachvollziehen der Beispiele im Buch unabdingbar sind. Kapitel 3, Projekt-Setup In Kapitel 3 beschreiben wir das von uns gewählte Projekt-Setup und lenken dabei das besondere Augenmerk auf die Build-Automatisierung. Wir motivieren unsere Entscheidung für den Einsatz des Build-Werkzeugs Apache Maven, erläutern die Grundlagen dieses Tools und das von uns gewählte Setup für das Beispielprojekt. Kapitel 4, Testen In Kapitel 4 motivieren wir zunächst kurz den Nutzen automatisierter Tests und testgetriebener Entwicklung im Kontext der JavaScript-Webentwicklung und stellen dann die grundsätzlichen Möglichkeiten vor, um JavaScript-Code automatisiert zu testen. Im Anschluss führen wir anhand von Beispielen in das Unit-Testen mit dem Testframework Jasmine ein. Abschließend stellen wir den JavaScript-Test-Runner JsTest- Driver für das automatisierte Ausführen der Test vor und erläutern die Integration der Testausführung in unser Projekt-Setup. Kapitel 5, Oberflächenkomponenten Wir beginnen die Entwicklung unserer Beispiel-App mit der Oberfläche und verwenden dafür jquery Mobile. Kapitel 5 erklärt zunächst den Nutzen beim Einsatz einer fertigen Komponentenbibliothek für die Entwicklung einer mobilen Web-App und stellt dann jquery Mobile und Sencha Touch als zwei Beispiele solcher Bibliotheken vor. Im Rest des Kapitels 5 und auch des ganzen Buchs verwenden wir dann jquery Mo- Mobile Web-Apps mit JavaScript 25

1 Einleitung bile zur Gestaltung der Benutzeroberfläche und stellen dieses Framework daher etwas ausführlicher vor. Im Anschluss stellen wir Möglichkeiten zum Testen der Oberfläche einer JavaScript-Web-App am Beispiel von Jasmine UI vor. Kapitel 6, Data Binding Die im Kapitel 5 erstellt Oberfläche ist statisch und enthält noch keine dynamischen Inhalte. In Kapitel 6 stellen wir das Entwurfsmuster Model View Controller als sinnvolles Konzept für die Strukturierung von JavaScript-Code vor, der eine statische Oberfläche zu einer richtigen App macht. Im Rest des Kapitels konzentrieren wir uns dann auf das Anbinden der Oberfläche an die Controller unsere Applikation. Dazu führen wir das JavaScript-Framework AngularJS ein und stellen seine Unterstützung für Two Way Data Binding vor. Kapitel 7, Backend-Kommunikation In Kapitel 7 zeigen wir, wie wir die dynamischen Inhalte der Applikation von einem Backend-Service laden können. Wir verwenden dazu das Entwurfsmuster Dependency Injection, um die unterschiedlichen Verantwortlichkeiten innerhalb unserer JavaScript-Web-App klar in lose gekoppelte Komponenten zu kapseln. Wir verwenden wieder das Framework AngularJS und dessen Unterstützung von Dependency Injection für die Umsetzung. Dabei stellen wir auch den Nutzen dieser Vorgehensweise für das Testen der Applikation heraus. Kapitel 8, Auf dem Weg zur mobilen Web-App Dieses Kapitel stellt die Architektur der vollständig fertig implementierten Applikation inklusive aller oben beschriebenen Use Cases und der sich daraus ergebenden Konsequenzen in Form von einigen Refactorings vor. Bis zu einer vollwertigen mobilen Web-App fehlen dann noch einige weitere Konzepte, die ebenfalls hier diskutiert werden, wie etwa das Einbinden von Wartedialogen, die Verwendung Wizard-artiger Dialoge, die Reaktion auf den Browser-Back-Button, das Nachladen bei größeren Datenmengen oder Performanceoptimierungen im Allgemeinen. 26

Kapitelübersicht Kapitel 9, Modularisierung und Build Die in diesem Buch betrachteten Web-Apps bestehen aus HTML, CSS und JavaScript-Sourcecode-Artefakten. Kapitel 9 erläutert, warum für diese Sprachen eine Modularisierung vorgenommen werden sollte und wie sich dies umsetzen lässt. Kapitel 10, Hybride Apps In den vorherigen Kapiteln haben wir gesehen, wie man eine mobile Web-App erstellt, die von einem Webserver abgerufen wird und innerhalb eines mobilen Browsers abläuft. In diesem Kapitel zeigen wir, wie man aus einer solchen Web-App eine native App erzeugt, die dann über den App Store der jeweiligen Zielplattform verteilt werden kann. Außerdem erweitern wir unsere Beispielanwendung um Zugriffsmöglichkeiten auf die Hardware des mobilen Geräts, was im nativen Kontext erst umfänglich möglich wird. Mobile Web-Apps mit JavaScript 27

2 JavaScript- Grundlagen Wir wollen in diesem Buch keine Einführung in JavaScript geben. Es gibt bereits einige sehr gute Bücher, die eine solche Einführung zum Ziel haben, beispielsweise Eloquent JavaScript von Marijn Haverbeke ( http://eloquentjavascript.net/), JavaScript: The Good Parts von Douglas Crockford oder JavaScript für Enterprise-Entwickler von Oliver Ochs. Auch für fortgeschrittene Fragestellungen beim Einsatz von JavaScript gibt es gute Bücher, wie beispielsweise JavaScript Patterns von Stoyan Stefanov. Wir möchten in diesem Kapitel in einer losen Sammlung auf die für unsere Beispiele relevanten Grundlagen eingehen und diese kurz erläutern. 2.1 Objekte und Objektliterale Objekte in JavaScript sind im wesentlichen Container für Properties mit ihren Werten. Im Grunde genommen sind JavaScript-Objekte also Hash Maps. Objekte können in JavaScript wie in Listing 2.1 gezeigt erzeugt und um Properties erweitert werden. 1 var customer = new Object(); 2 customer.firstname = "John"; 3 customer.lastname = "Doe"; Listing 2.1: Erzeugen und initialisieren von Objekten in JavaScript In Zeile 1 erzeugen wir ein neues Objekt mithilfe der Konstruktorfunktion Object und dem Operator new. In den Zeilen 2 und 3 erweitern wir dieses neue Objekt um zwei Properties und initialisieren diese. Eine alternative Möglichkeit, ein leeres Objekt zu erzeugen, ist die Verwendung Mobile Web-Apps mit JavaScript 29