Luca Perullo
Tutte le note
/Tecnologie

Headless CMS e Jamstack spiegati semplici: la tecnologia che rende i siti più veloci

Headless è una buzzword che spaventa molti imprenditori. In realtà è la separazione di due cose, e ti dà siti 10x più veloci. Vediamolo senza tecnichesi.

"Headless" suona tecnico, ma il concetto è semplice: separi DOVE scrivi i contenuti da DOVE li mostri. Sembra un dettaglio, ma cambia performance, sicurezza, costi e flessibilità del sito. Ecco cosa significa per chi deve decidere — senza buzzword.

Il sito tradizionale (monolitico) vs headless

Sito tradizionale (es. WordPress classico). Stesso software fa due cose:

  • Backend dove scrivi articoli, prodotti, contenuti
  • Frontend che genera HTML dal database e lo manda al visitatore

Tutto interconnesso, tutto sulla stessa macchina.

Sito headless. Due cose separate:

  • CMS (la testa): dove scrivi contenuti. Es. Sanity, Contentful, Strapi, Payload. Vive su un servizio dedicato.
  • Frontend (il sito): un'app super-veloce in Next.js/Astro che legge i contenuti dal CMS via API e li trasforma in pagine.

Sembra più complicato, ma in pratica è meglio.

Perché conviene

1. Performance brutale.

Un sito Jamstack pre-renderizzato (le pagine HTML sono già pronte sul server) carica in 200–800ms da qualsiasi parte d'Italia. WordPress senza caching rabbioso parte da 1.5–3 secondi.

Differenza concreta: mobile, 4G, primo paint sotto 1 secondo. SEO migliore, conversioni migliori.

2. Sicurezza per design.

Il sito frontend non parla MAI direttamente con un database. È HTML statico (o quasi). Niente WordPress da bucare, niente plugin obsoleti. La superficie di attacco si riduce del 95%.

3. Marketing fa marketing senza chiamare lo sviluppatore.

Il CMS headless è disegnato per editor: scrivi, modifichi, pubblichi. Il sito si aggiorna automaticamente. Niente "ci serve uno sviluppatore per cambiare un titolo".

4. Costi infrastruttura più bassi.

Hosting un sito Jamstack (Vercel, Cloudflare, Netlify) costa €0–20/mese a traffico medio. WordPress veloce con plugin di caching, CDN, upgrade hosting: €40–150/mese.

A 5 anni il TCO (total cost of ownership) Jamstack è 30–50% inferiore.

Quando NON conviene headless

Sito molto piccolo (5 pagine, niente blog). Setup overhead non si giustifica. Un sito vetrina semplice in WordPress base costa meno e va bene.

Cliente che vuole modificare design dal CMS. Builder visuali (Webflow, Elementor) hanno UX più immediata. Headless richiede che il design sia stabile.

Funzionalità WP-specific cruciali. Es. WooCommerce con 50 plugin custom. Migrare costa di più del valore.

I CMS headless più usati nel 2026

  • Sanity — premium, ottimo studio, query potenti, hosted SaaS, prezzi ragionevoli sotto i 100k visit/mese
  • Contentful — enterprise, robusto, prezzi alti
  • Strapi — open-source, self-hosted, controllo totale, manutenzione tua
  • Payload — emergente, TypeScript first, gratis self-hosted
  • Notion / Airtable — light, ok per blog amatoriali, non scala

Frontend più usati

  • Next.js — il più potente, full-stack, deploy istantaneo su Vercel
  • Astro — ottimo per siti content-heavy, zero JS by default
  • Nuxt.js — Vue equivalent di Next
  • SvelteKit — emergente, syntax pulito, performance top

Quando ha senso il salto

Se sei in WordPress e:

  • Performance è un problema dichiarato (Search Console rosso)
  • Sicurezza è una preoccupazione (siti bucati in passato)
  • Marketing fa contenuti regolari ed è frustrato dal CMS
  • Stai per fare un restyling comunque

...allora vale la pena valutare Jamstack come parte del progetto.

Range di costo per progetto

  • Migrazione sito esistente WP → Jamstack (mantenendo contenuti) — €6.000–15.000
  • Sito Jamstack nuovo da zero (con headless CMS configurato) — €8.000–20.000
  • E-commerce headless (Shopify Hydrogen, Medusa) — €15.000–40.000+

L'investimento iniziale è più alto. Il TCO a 3–5 anni è più basso. La performance è incomparabile.

Vuoi capire se ha senso per il tuo caso? Scrivimi — 30 minuti di analisi e ti dico se conviene o no, onestamente.

Continua a leggere