Jamstack
Proof of Concept

Human Digital Development
26 juli 2022
Albert Boersen

Inleiding

Wie kent ze niet, de grote CMS pakketten die "alles" kunnen. De pakketten die op servers geïnstalleerd moeten worden met de nadelen van dien. Of de CMS pakketten die het niet kunnen maar waar je "eenvoudig" een plugin voor kan installeren (soms onveilig en vaak ongetest). Wie kent het niet, het beheer van die pakketten en alles wat er nog meer bij komt kijken, zoals risicovolle releases en laten we al helemaal niet beginnen over slechte performance van je site of de kosten van sommige van die pakketten.

Al een behoorlijke tijd zijn er ook Headless oplossingen zoals Kontent, Heartcore of Contentful. Maar wat als je al deze extra mogelijkheden van zo'n groot CMS nu eens ook als losstaande oplossingen gaat zien?

Dat is (in mijn ogen) het principe van Jamstack. Voor iedere oplossing is er wel een gespecialiseerd SaaS (Software as a Service) pakket.

Ik wil jullie graag meenemen in mijn reis door de wereld van Vercel, Uniform en laten zien waarom ik denk dat dit de nieuwe standaard gaat worden.

Inhoud

  • Inleiding
  • Jamstack
  • Headless CMS
  • Uniform
  • Formulieren
  • NextJS
  • Vercel
  • Proof of Concept
  • Conclusie
  • Demo
  • Links

Jamstack

In de inleiding heb ik het al kort gehad over Jamstack. Maar wat is het nu eigenlijk? De JAM in jamstack staat voor:

  • (J)avascript
  • (A)PI's
  • (M)arkup

Dus eigenlijk zeg je dat je met Javascript en Markup gebruik maakt van API's die bijvoorbeeld je content uit een headless CMS haalt en je formulieren in een ander SaaS pakket wegschrijft. Dit alles wordt dan op de "Edge" van het web geplaatst zodat het snel bereikbaar is voor het grote publiek.

Headless CMS

Als headless CMS heb ik zelf ervaring met Kontent, Heartcore en Contentful. De laatste heb ik gebruikt bij mijn 'Proof of concept'. Natuurlijk zitten er verschillen tussen de systemen, maar wat belangrijk is om te weten, is dat je het concept van een traditioneel CMS van een boomstructuur van je content los moet laten. Headless wil eigenlijk zeggen; je content is nu bereikbaar via verschillende API endpoints, daarmee haal je alle agenda items op en dat gebruik je in je applicatie om een agenda overzicht te tonen. Klinkt dit ingewikkeld? Ik zal even een voorbeeld laten zien:

Xperience CMS content tree (traditioneel)

Contentful alle page types in een relatieloze "bak" (headless)

Uniform

Visualisatie

Om een traditioneel CMS tegemoet te komen kan je gebruik maken van een 'visualisatie' SaaS pakket. In mijn PoC ben ik Uniform gaan onderzoeken zodat er ook direct gebruik gemaakt kon worden van personalisatie. In uniform kan je blokjes aanmaken op een canvas en dat is dan de volgorde van bijvoorbeeld een pagina in je site. 

Personalisatie

Ook zijn er scores bij te houden gebaseerd op acties die op je site plaats vinden. Stel je hebt op een developer pagina een actie staan met een score en een blokje in je canvas die daar naar luistert zal dat blokje getoond worden. Super tof natuurlijk als je veel campagnes op je site hebt en je de bezoeker gebaseerd op eerdere acties sneller naar een boeiend resultaat wil brengen. 

Koppeling met Headless

Uniform kan je configureren zodat het direct werkt met een headless CMS zoals Contentful. Dit werkt erg handig en zorgt ervoor dat je als content editor makkelijk vanuit je opbouw van je pagina naar je onderdelen met content in je headless CMS kan wisselen.

Formulieren

Een boeiend punt wat je vaak terug ziet komen als motivatie om vast tee houden aan een traditioneel CMS zijn een ingebouwde formulieren modules. En inderdaad, dat is ook zeker handig om in je CMS te hebben zitten, maar hoe zou je dat kunnen oplossen op een Jamstack manier?

In mijn zoektocht naar een kant en klare formulieren engine ben ik van alles tegengekomen. Maar echt een kant en klare engine die je makkelijk kan integreren kon ik niet vinden. Wat de meeste engines deden was de uiteindelijke HTML van het formulier als output geven. Dat zou je dan in je Markup kunnen gebruiken. Natuurlijk is dat handig, maar dan kun je net zo goed een developer en formulier laten maken in bijvoorbeeld NextJS. Kan snel gemaakt worden en binnen een traditioneel CMS heb je toch ook vaak nog een developer nodig die het formulier nog wat tweaked of iets implementeert.

Maar wat doe je dan met de data die ingezonden wordt via een formulier? Je hebt namelijk geen traditioneel CMS meer die dat voor je op kan slaan. Mijn oplossing was daarvoor Basin. Een duidelijke SaaS oplossing die alle formulieren die worden gestuurd naar een API endpoint opslaat en zelfs notificaties en autoresponders kan sturen.


NextJS

NextJS is een framework gebaseerd op React. Het combineert de kracht van een statische html site en het server side renderen van een "klassieke" server / client website. Meer hierover bij Vercel.

Wat ik nog over NextJS wil melden is dat het niet alleen de voordelen biedt van de modulaire opbouw zoals ook wel bekend bij React sites, maar het biedt ook gigantisch veel optimalisatie voor bijvoorbeeld afbeeldingen en responsive.

NextJS bouwt voordat het een echte site maakt alle codes om tot een statische website (HTML). Op deze manier zijn alle API aanroepen al gedaan en is de website super snel.

Ook is het voordeel van de modulaire opbouw dat iedere developer zich snel wijs kan maken binnen een project.


Vercel

Om uiteindelijk de PoC publiekelijk zichtbaar te maken in plaats van alleen op een laptop moet het nog ergens gehost worden. Maar we werken met Jamstack, dus we gebruiken geen traditionele web servers zoals Apache of IIS.

Mijn git repository is gekoppeld met Vercel. Zodra er code door wordt gezet naar de productie branch pakt Vercel dit op en gaat het ombouwen tot een statische website. Dit is een proces van een halve minuut tot een minuut, natuurlijk afhankelijk van hoeveel er omgebouwd moet worden en komt bij succes (schrik niet) automatisch op productie te staan.

Als je werkt met feature branches en zo'n branch ook pushed naar de git repository pakt Vercel dit ook op en zet het ook om in een statische site. Deze komt dan niet op productie terecht maar krijgt een eigen URL. Super handig, want deze URL kan je delen met je tester of Product owner. Op deze manier kan je je features snel checken met de rest van je team en kan het ook sneller naar productie.

Releasen naar productie ga je ook veel sneller doen, Vercel houdt namelijk de eerdere versies bij. Je kan daar altijd makkelijk naar terug schakelen, doordat het natuurlijk statische HTML is en dat zijn alleen maar bestanden. Releasen gaat ook zonder downtime en performance verlies.


Proof of Concept

Tot nu toe was het veel theorie over wat ik waarvoor heb gebruikt en wat het doet, maar hoe ziet het er nu allemaal uit? Bekijk de volgende video waarin ik laat zien hoe het allemaal met elkaar in verbinding staat:


Conclusie

Mijn conclusie is dat de flexibiliteit van Jamstack zoveel beter is dan een log CMS die claimt alles te kunnen. Wat je vaak ziet is dat een groot CMS het wel kan wat het claimt, maar dat het net niet lekker werkt. Een SaaS oplossing die zich specialiseert in dat ene onderdeel is altijd beter dan een groot CMS die het erbij heeft gemaakt.

De snelheid van NextJS en Vercel blijft mij verbazen, het statische site voordeel is zo gigantisch groot, het kostte ook bijna geen moeite om een 100% score te halen binnen Lighthouse.

Het feit dat features worden bekeken door een Product Owner of Tester na het committen van je changes scheelt ook veel in het ontwikkelproces.

Uniform biedt met canvas de mogelijkheid om de opbouw van je pagina's te bepalen met blokken die je kan verslepen. Daarnaast is de mogelijkheid om te personaliseren ook erg fijn, stel je hebt gezocht op een bepaalde behandeling in een ziekenhuis en je krijgt automatisch een link naar een folder te zien op een volgende pagina naast de contact gegevens (is maar 1 van de vele voorbeelden).

Mijn eindvraag is dan ook, waarom ben je nog niet over naar Jamstack? Mijn collega's van Human Digital kunnen je hierbij ondersteunen.

Demo

Hier kan je mijn PoC vinden: Serverless-Digital 

Links

Cookies
Deze site gebruikt geanonimiseerde cookies. Klik op "Akkoord" als je akkoord gaat met het gebruik van cookies, of klik op "Aanpassen" om je voorkeuren te bepalen.
Deze site gebruikt geanonimiseerde cookies.