Skip to content

Commit

Permalink
fix: headline level
Browse files Browse the repository at this point in the history
  • Loading branch information
d-koppenhagen committed Jan 26, 2024
1 parent 918ffa1 commit 65a9efd
Showing 1 changed file with 17 additions and 17 deletions.
34 changes: 17 additions & 17 deletions src/docs/blog/2024/2024-01-25-Evolution-der-Webentwicklung.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -17,13 +17,13 @@ ifndef::imagesdir[:imagesdir: ../../images]

In diesem persönlichen Rückblick tauchen wir ein in die faszinierende Welt der Webentwicklung – von den frühen Tagen des manuellen Codings bis hin zu den modernen Technologien, die heute den Standard setzen. Begleitet mich auf meiner Reise durch die Zeit, in der sich HTML, CSS und JavaScript von Grund auf verändert haben und entdeckt, wie sich die Herausforderungen und Lösungen in der Webentwicklung im Laufe der Jahre gewandelt haben. Von den ersten Schritten mit einfachen Tools bis hin zu den komplexen Frameworks und Methoden von heute – dies ist eine Geschichte von Innovation, Lernen und ständiger Weiterentwicklung.

== Zuerst ein paar Meilensteine der Webentwicklung tabellarisch zusammengefasst:
=== Zuerst ein paar Meilensteine der Webentwicklung tabellarisch zusammengefasst:

1. 1991 erste Webseite mit HTML
2. 1995 PHP und JavaScript
3. 1996 CSS
2. 1995 PHP und JavaScript
3. 1996 CSS
------------- bis hierhin kaum automatisiertes Deployment möglich (z. B. über FTP)
4. 2000 SVN
4. 2000 SVN
5. 2003 Wordpress (Joomla/Typo3 etc.)
6. 2005 GIT
------------- Versionierung
Expand All @@ -41,45 +41,45 @@ In diesem persönlichen Rückblick tauchen wir ein in die faszinierende Welt der
17. 2020 https://vitejs.dev[Vite]
18. 2022 Generatoren für Frontend/Backend Kombinationen https://refine.new[refine.new], https://redwoodjs.com[RedwoodJS], https://blitzjs.com[Blitz.js]
19. 2023 Ende des Internet Explorers
20. 2023 React Server Components
20. 2023 React Server Components

Mehr Details und ausführlichere Infos gibt es unter anderem auf:
- https://designmodo.com/history-website-building/[designmodo.com: The Short History of Website Building]
- https://dev.to/snickdx/a-brief-history-of-the-web-part-4-194b[Nicholas Mendez: A "Brief" History of the Web Part 4]
- https://www.viget.com/articles/what-even-are-react-server-components/?token=PFnI6MT715nmYK0BZzQEiRsYQ7w_x5SP[Nick Telsan: What Even Are React Server Components]
- https://jessedit.tech/articles/react-server-components/1-background/?ck_subscriber_id=1652261910[Jesse Pence: React Server Components]

== Meine ersten Erfahrungen mit dem Internet
=== Meine ersten Erfahrungen mit dem Internet

Wenn ich mich an die Anfänge meiner Tätigkeit erinnere, haben wir HTML, CSS, PHP und jQuery mit BBedit selbst geschrieben, gespeichert und manuell per FTP auf Server hochgeladen. Das Beste, was es damals gab, war das Programm Transmit, mit dem einzelne Ordner synchronisiert werden konnten. Alles war sehr fehleranfällig, ohne Versionierung und daher schwer bis gar nicht testbar – nur manuell. jQuery-Plugins wurden mit Abhängigkeiten zu unterschiedlichen jQuery-Versionen benutzt, die nicht unbedingt kompatibel waren. Man musste jedes Mal hoffen, dass die Webseite noch funktionierte, nachdem man Code hinzugefügt hatte. Was mich immer am meisten geärgert hat, war ein Flackern, sobald das JavaScript geladen wurde und über das PHP-gerenderte HTML noch extra DOM-Elemente legte.
Wenn ich mich an die Anfänge meiner Tätigkeit erinnere, haben wir HTML, CSS, PHP und jQuery mit BBedit selbst geschrieben, gespeichert und manuell per FTP auf Server hochgeladen. Das Beste, was es damals gab, war das Programm Transmit, mit dem einzelne Ordner synchronisiert werden konnten. Alles war sehr fehleranfällig, ohne Versionierung und daher schwer bis gar nicht testbar – nur manuell. jQuery-Plugins wurden mit Abhängigkeiten zu unterschiedlichen jQuery-Versionen benutzt, die nicht unbedingt kompatibel waren. Man musste jedes Mal hoffen, dass die Webseite noch funktionierte, nachdem man Code hinzugefügt hatte. Was mich immer am meisten geärgert hat, war ein Flackern, sobald das JavaScript geladen wurde und über das PHP-gerenderte HTML noch extra DOM-Elemente legte.
Die folgenden Probleme sind meiner Meinung nach die größten beim klassisch gerenderten Web: Wann ist der DOM fertig, wann ist das JS geladen und wird ausgeführt, wer hat bei intensiven Seiten „das Sagen“ – das Frontend oder das Backend (Routing, Views)?

== Wie wurden Webseiten 2014 gebaut?
=== Wie wurden Webseiten 2014 gebaut?

Nach meinem Studium habe ich in Hamburg bei AboutYou in einer IT-Agentur gearbeitet, die nach Scrum ihren Arbeitszyklus gestaltet und schon damals diverse Tools zum Bauen des Frontends benutzt hat. Da die Tools alle am Anfang ihres Lebenszyklus waren, mussten mindestens drei Package-Manager und Erweiterungen installiert werden, bevor die Webseite gebaut werden konnte. Gebaut? Ja, das war die Zeit, in der Grunt und Webpack eine moderne und strukturierte Frontendentwicklung ermöglicht haben. Vorbei waren die Zeiten mit unterschiedlichen Encodings und Zeilenumbrüchen. Was für ein Gefühl es war, lokal einen Befehl in der Kommandozeile aufzurufen und die zu entwickelnde Webseite auf dem eigenen Gerät zu sehen – heute Standard. Hier lernte ich zum ersten Mal Package-Manager und Versionierung kennen. Und noch ein Thema kam auf: IDEs für Webentwicklung. Bisher war der beste Freund der Inspektor im Browser, eine lokale, beim Entwickler stattfindende Überprüfung oder Unterstützung konnten bis dahin nur die „richtigen“ Programmiersprachen und die dazugehörigen teuren IDEs (z. B. IntelliJ) bieten. Mit Atom gab es eine IDE, die schnell startete, sich nur um Websprachen kümmerte und über Plugins erweiterbar war. Jetzt gab es Autovervollständigung für HTML/JS/CSS und über Webpack konnten alle Dateien optimiert, komprimiert und kombiniert werden.

== Wie ist der Stand heute?
=== Wie ist der Stand heute?

Sehr gut! Viele Probleme der Vergangenheit sind verschwunden (Internet Explorer existiert nicht mehr, schlechte Kompatibilität der Browser) und es gibt eine Reihe von Möglichkeiten, Frontends mit Frameworks zu bauen, die alle ihre Vor- und kleinen Nachteile haben. Z. B. hat sich Visual Studio Code als Nachfolger von Atom zum (kostenlosen) Standard für Webentwicklung mit noch mehr Möglichkeiten zur generellen Verbesserung gemausert. Frontend-Frameworks gibt es viele (und es kommen immer mehr dazu) – durchgesetzt haben sich aktuell React, Angular, Vue.js und Svelte.

== Wie helfen moderne Frontends bei der Performance?
=== Wie helfen moderne Frontends bei der Performance?

Schauen wir uns hierzu den Ablauf einer klassischen Webseite an: Ein Endgerät ruft die URL unserer Seite auf. Der Server antwortet je nach Session/Cookie/Authentication mit einer Login-Seite oder dem gerendertem HTML eines PHP-Skripts. Evtl. wurde der Client auf eine andere URL umgeleitet. Das HTML wird vom Browser interpretiert und JS/CSS/Bilder werden nachgeladen. Das CSS sorgt für das Styling der Seite. Das ausgelieferte JavaScript wird interpretiert, verändert das DOM und lädt neue Daten nach, und das wiederholt sich, wie hier beschrieben. Alle Schritte benötigen Zeit und führen zu einer mehrsekündigen Wartezeit, bis die Webseite benutzt werden kann.
== Hier der Aufbau eines modernen Frontends mit BFF (Backend for Frontend):

=== Hier der Aufbau eines modernen Frontends mit BFF (Backend for Frontend):

Der Client fragt den Server an und erhält HTML, JS und CSS sowie den Login-Status vom Backend, und zwar so aufbereitet, dass der Browser es direkt darstellen kann, ohne weitere Schleifen zu drehen. Weitere Inhalte werden z. B. als JSON nachgeladen und im Browser mit JavaScript gerendert. Zusätzlich gibt es für alle JS-Frameworks Bundler, die beim Bauen der auszuliefernden Dateien diese optimal aufbereiten, sodass der User innerhalb kürzester Zeit mit dem Frontend interagieren kann.

== Wie baue ich Frontends?
=== Wie baue ich Frontends?

Mein Lieblings-Javascript-Framework ist React. Eine gute Übersicht über andere JS-Frameworks und was sie unterscheidet, findet ihr z. B. auf themer.dev[https://themer.dev/blog/the-single-most-important-factor-that-differentiates-front-end-frameworks].
Mein Lieblings-Javascript-Framework ist React. Eine gute Übersicht über andere JS-Frameworks und was sie unterscheidet, findet ihr z. B. auf themer.dev[https://themer.dev/blog/the-single-most-important-factor-that-differentiates-front-end-frameworks].
Von dieser Seite kommt folgendes Zitat: „Reacts change detection paradigm is straightforward: the application state is maintained inside the framework (with APIs exposed to the developer for updating it) so that React knows when to re-render.“ Und was heißt das jetzt? Nicht mehr der Browser oder das Backend entscheiden, auf welcher URL was passiert, sondern das Frontend. Und wenn im Frontend eine Aktion ausgelöst wird, entscheidet auch das Frontend, was passiert. Das heißt nicht, dass es kein Backend gibt oder dass z. B. Validierung nur auf der Frontendseite passiert. Sicherheit im Web sollte der wichtigste Aspekt sein.

== Bevor ich mit einem neuen Projekt anfange
=== Bevor ich mit einem neuen Projekt anfange

Was sich für mich als Erfolgsrezept herausgestellt hat: Sich am Anfang eines Neu- oder Umbaus einer Seite viel Zeit nehmen, um passende Libraries/Frameworks zu finden, die einem das Leben erleichtern und diese zu benutzen (UI Components, Accessibility, Icons, etc.). Am besten auf bekannte Frameworks setzen, die regelmäßig aktualisiert/gewartet werden.

== Abschließend ein paar Wünsche an das Frontend, welches ihr baut:
=== Abschließend ein paar Wünsche an das Frontend, welches ihr baut:

- Macht die Webseite responsive (Probiert eure Webseite mit unterschiedlichen Geräten in unterschiedlichen Auflösungen aus)
- Räumt euren Header-Bereich auf und nutzt z. B. https://realfavicongenerator.net[ealfavicongenerator.net], um für alle ein schönes Favicon zu zaubern
Expand All @@ -91,4 +91,4 @@ Was sich für mich als Erfolgsrezept herausgestellt hat: Sich am Anfang eines Ne
- Macht Hover-Styles für Links
- Wenn sich die Gui geändert hat, nachdem geklickt wurde, ändert die URL

Das war die Reise durch 20 Jahre Webentwicklung – ich bin sehr gespannt, was in 20 Jahren im Web alles möglich ist.
Das war die Reise durch 20 Jahre Webentwicklung – ich bin sehr gespannt, was in 20 Jahren im Web alles möglich ist.

0 comments on commit 65a9efd

Please sign in to comment.