Skip to content

Coding Weekend 2013-02 JavaScript Framework Evaluation

Notifications You must be signed in to change notification settings

dataduke/CodeWe1302JavaScript

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

45 Commits
 
 

Repository files navigation

CodeWe1302JavaScript

Coding Weekend Project 2013-02 JavaScript Framework Evaluation

  • Allgemeines
    1. Einführung
    1. Grundlagen zum JavaScript-Stack
    1. JavaScript-Frameworks
    1. Testumfeld
    1. Evaluierung
    1. Zusammenfassung und Fazit
  • Referenzen

Allgemeines

Struktur

  • Ausarbeitung für Whitepaper in diesem Repo
  • Entwicklung von Testapplikationen in ausgelagerten Repos (Teilprojekte)

Verzeichnis der Projekt-Repos mit umgesetzten Testapplikationen

1. Einführung

Projektmotivation

Für mehrschichtige Applikationen (Multitier Enterprise Applications) bestehen neben den Möglichkeiten, welche der Java- oder .NET-Stack bietet, eine Vielzahl an JavaScript-Frameworks um den Frontend-Layer (Tier) zu gestalten.

Aktuell ist die mögliche Auswahl an verfügbaren und aktuellen Frameworks, welche auf JavaScript (JS) setzen, in der Tat so hoch, dass die genauen Vor- und Nachteile der einzelnen Lösungen hinsichtlich Verfügbarkeit und Aktualität der Projektdokumentation, Einarbeitungszeit, Dauer und Qualität des Framework-Lifecycles sowie deren technische Eleganz bei der Implementierung, nicht bekannt oder hinreichend dokumentiert vorzufinden ist.

Um eine Entscheidungsbasis über die allgmeine Reife für den Einstatz in industriellen Großprojekten zu etablieren, oder gar die Entscheidung für eine bestimmte Kombination an JavaScript-Rahmenwerken zu ermöglichen soll ein Vergleich diverser JS-Frameworks pragmatisch vollzogen werden.

Grundidee

  • Evaluierung ausgewählter JavaScript-Frameworks durch Realisierung einer äquivalenten Testapplikation
  • Vergleiche hierzu ähnliches Projekt mit ToDo-App als Referenz: http://addyosmani.github.com/todomvc/

2. Grundlagen zum JavaScript-Stack

Aufbau des Frontends (Layers und Dependencies)

Top-Down-Architektur:

  1. Eigene Applikation (Testapplikation)
  2. JS Framework (Framework zur Evaluierung)
  3. jQuery und andere JS Framework Dependencies (on Top von Protoype/Utilities)
  4. PrototypeJS und/oder andere Utility-Frameworks (Low-Level-Funktionen und Patterns für Objekte)
  5. JavaScript

Funktionalitäten von JS-Frameworks

Gemeinsamkeiten (Häufige Standards):

  • Templating
  • Model-Binding
  • Pageflow, Routing
  • Messages, REST
  • JS Dokumentation

Unterschiede:

  • Patterns: MVC (Model-View-Controller) vs. MVVM (Model-View-ViewModel)

3. JavaScript-Frameworks

Ausgewählte Testkandidaten

Kurzvorstellung und Beschreibungen

siehe Dokumentation in einzelnen Projekt-Repos

4. Testumfeld

Geschäftsprozess

Kundenerfassung mit Personendaten, Adressdaten und Bestätigung der gemachten Angaben.

Felder der Testapplikation (Referenzimplementierung)

Personendaten (Page):

  • Name und Vorname: Text-Fields (required)
  • Geburtstag: Date-Field mit DatePicker (required)
  • Kreditkarten Nummer: Number-Field (required, genau 10-stellig)

Adressdaten (Page):

  • Land: Drop-Down-Box (required, mit Default-Wert)
  • Strasse und Hausnummer: Text-Field und Number-Field (required)
  • PLZ und Ort: Number-Field (Validierung mit automatischer Befüllung des Ortes)
  • Wohnhaft seit: Date-Field mit DatePicker (required)
  • if (Wohnhaft seit) < 2 Jahre: Neue Adressegruppe mit vorheriger Adresse (Toogle show/hide)

Zusammenfassung (Page):

  • Datenwiedergabe (Labels, Output Fields)
  • Datenbestätigung (Checkbox)
  • Submit (Gemockter REST-Call zum Backend)

Ende (Page):

  • Danke (Text)
  • Neubestellung (Link zu Personendaten, Loop)

Features der Testapplikation

siehe Beschreibung bei https://github.com/sebastianfuss/backbone-test

5. Evaluierung

Evaluierungskriterien

  • Pageflow, Routing
  • Model, Data-Binding
  • Felderdeklaration, Validierung
  • REST-Anbindung
  • Dokumentation
  • Unit-Tests für Validierung, Pageflow

Evaluierungsergebnisse

siehe Dokumentation in einzelnen Projekt-Repos

6. Zusammenfassung und Fazit

TBD

Referenzen

Unterstützende Frameworks

Tools und Literatur

About

Coding Weekend 2013-02 JavaScript Framework Evaluation

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published