Ultimamente si è parlato molto di app web progressive. Si tratta ancora di un modello relativamente nuovo, ma i suoi principi possono migliorare allo stesso modo le app create con JS, React, Polymer, Angular o qualsiasi altro framework. In questo post, riassumerò alcune opzioni e app di riferimento per iniziare a utilizzare la tua app web progressiva oggi stesso.
Che cos'è un'app web progressiva?
È importante ricordare che le app web progressive funzionano ovunque, ma sono ottimizzate nei browser moderni. Il miglioramento progressivo è una colonna portante del modello.
Aaron Gustafson ha paragonato il miglioramento progressivo a un M&M con arachidi. La nocciola è costituita dai tuoi contenuti, la copertura di cioccolato è il livello di presentazione e il codice JavaScript è la copertura del caramello duro. Questo livello può variare di colore e l'esperienza può variare in base alle funzionalità del browser che lo utilizza.
Pensa alla shell come al luogo in cui possono essere ospitate molte funzionalità delle app web progressive. Sono esperienze che combinano il meglio del web e il meglio delle app. Sono utili agli utenti fin dalla prima visita in una scheda del browser, senza bisogno di installazione.
Man mano che l'utente instaura una relazione con queste app tramite l'uso ripetuto, le app rendono ancora più dolce la caramella: caricamento molto rapido su connessioni di rete lente (grazie ai service worker), invio di notifiche push pertinenti e un'icona di primo livello nella schermata Home dell'utente che può caricarle come esperienze di app a schermo intero. Possono anche usufruire di banner per l'installazione di app web intelligenti.
Le app web progressive sono
- Progressivi: funzionano per tutti gli utenti, indipendentemente dal browser scelto, perché sono creati con il potenziamento progressivo come tenant di base.
- Adattabile: si adatta a qualsiasi fattore di forma, computer, dispositivo mobile, tablet o qualunque altro dispositivo.
- Indipendenza dalla connettività: migliorata con i service worker per lavorare offline o su reti di bassa qualità.
- Come app: utilizza il modello di shell dell'app per fornire navigazioni e interazioni simili a quelle delle app.
- Aggiornata: sempre aggiornata grazie al processo di aggiornamento dei worker di servizio.
- Sicura: pubblicata tramite TLS per impedire lo snooping e garantire che i contenuti non siano stati manomessi.
- Rivelabili: sono identificabili come "applicazioni" grazie ai manifest W3C e all'ambito di registrazione dei service worker che consentono ai motori di ricerca di trovarle.
- Possibilità di ricoinvolgimento: semplifica il ricoinvolgimento tramite funzionalità come le notifiche push.
- Installabile: consente agli utenti di "conservare" le app che ritengono più utili nella schermata Home senza dover utilizzare un app store.
- Collegabile: condividi facilmente tramite URL e non richiede un'installazione complessa.
Inoltre, le app web progressive non sono un'esclusiva di Chrome per Android. Di seguito possiamo vedere l'app web progressiva Pokedex in esecuzione in Firefox per Android (beta) con le funzionalità iniziali di Aggiungi alla schermata Home e della memorizzazione nella cache dei worker di servizio che funzionano perfettamente.
Uno degli aspetti interessanti della natura "progressiva" di questo modello è che le funzionalità possono essere sbloccate gradualmente man mano che i fornitori di browser offrono un supporto migliore. Le app web progressive come Pokedex funzionano perfettamente anche in Opera su Android, con alcune differenze significative nell'implementazione:
Per approfondire le app web progressive, leggi il post del blog originale di Alex Russell che le presenta. Paul Kinlan ha anche creato un tag Stack Overflow molto utile per le app web progressive che vale la pena di provare.
Principi
Manifest dell'app web
Il file manifest consente alla tua app web di avere una presenza più simile a quella nativa nella schermata Home dell'utente. Consente di avviare l'app in modalità a schermo intero (senza barra degli URL) e di controllare l'orientamento dello schermo. Inoltre, nelle versioni recenti di Chrome su Android supporta la definizione di una schermata iniziale e di un colore del tema per la barra degli indirizzi. Viene utilizzato anche per definire un insieme di icone in base alle dimensioni e alla densità utilizzate per la schermata iniziale e l'icona della schermata Home sopra menzionate.
Un file manifest di esempio è disponibile nel Web Starter Kit e nei Samples di Google Chrome. Bruce Lawson ha scritto un generatore di manifest e Mounir Lamouri ha anche scritto un pratico strumento di convalida del manifest web che vale la pena provare.
Nei miei progetti personali, mi affido a realfavicongenerator per generare icone con le dimensioni corrette sia per il manifest dell'app web sia per l'utilizzo su iOS, computer e così via. Il modulo Node favicons è in grado di generare un output simile anche durante il processo di compilazione.
I browser basati su Chromium (Chrome, Opera e così via) supportano i manifest delle app web oggi, con Firefox che sviluppa attivamente il supporto e Edge che li elenca come in fase di considerazione. WebKit/Safari non hanno ancora pubblicato indicatori pubblici sulle loro intenzioni di implementare la funzionalità.
Per ulteriori dettagli, leggi App web installabili con il manifest dell'app web in Chrome per Android su Web Fundamentals.
Banner "Aggiungi a schermata Home"
Chrome su Android supporta l'aggiunta del tuo sito alla schermata Home da un po' di tempo, ma le versioni recenti supportano anche la proposta proattiva di siti da aggiungere utilizzando i banner di installazione di app web nativi.
Affinché le richieste di installazione dell'app vengano visualizzate, la tua app deve:
- Avere un manifest dell'app web valido
- Essere pubblicata tramite HTTPS (visita letsencrypt per un certificato senza costi)
- Avere un service worker registrato valido
- Essere visitato due volte, con almeno 5 minuti tra una visita e l'altra
Sono disponibili diversi esempi di banner per l'installazione di app, che vanno dai banner di base a casi d'uso più complessi come la visualizzazione di applicazioni correlate.
Service worker per la memorizzazione nella cache offline
Un service worker è uno script che viene eseguito in background, separatamente dalla pagina web. Risponde agli eventi, incluse le richieste di rete effettuate dalle pagine che pubblica. La durata di un worker di servizio è intenzionalmente breve.
Si attiva quando riceve un evento ed esegue solo il tempo necessario per elaborarlo. Il servizio worker ti consente di utilizzare l'API Cache per memorizzare nella cache le risorse e può essere utilizzato per offrire agli utenti un'esperienza offline.
I worker di servizio sono molto efficaci per la memorizzazione nella cache offline, ma offrono anche miglioramenti significativi delle prestazioni sotto forma di caricamento istantaneo per le visite ripetute al tuo sito o alla tua app web. Puoi memorizzare nella cache la shell dell'applicazione in modo che funzioni offline e compilarne i contenuti utilizzando JavaScript.
Un insieme completo di esempi di service worker è disponibile negli esempi di Google Chrome. La cookbook offline di Jake Archibald è un must read e ti consiglio vivamente di provare la procedura dettagliata di Paul Kinlan per creare la tua prima app web offline se non hai dimestichezza con i worker di servizio.
Il nostro team gestisce anche una serie di utilità di assistenza e strumenti di compilazione per i worker di servizio che riteniamo utili per ridurre il sovraccarico durante la configurazione dei worker di servizio. Sono elencate nella pagina Librerie Service Worker. I due principali sono:
- sw-precache: uno strumento di compilazione che genera uno script di service worker utile per eseguire il precaching della shell dell'app web
- sw-toolbox: una libreria che fornisce la memorizzazione nella cache di runtime per le risorse utilizzate di rado
Jeff Posnick ha scritto un breve tutorial su sw-precache chiamato Offline-first, fast, with the sw-precache module (Offline-first, veloce, con il modulo sw-precache) e un codelab sullo stesso strumento che potresti trovare utile.
Chrome, Opera e Firefox hanno implementato il supporto per i worker di servizio, mentre Edge ha indicatori pubblici positivi sull'interesse per la funzionalità. Safari ha brevemente menzionato il proprio interesse per questa funzionalità nel piano quinquennale proposto da un ingegnere.
Notifiche push per il ricoinvolgimento
In pratica, puoi creare app web con cui gli utenti possono interagire al di fuori di una scheda. Il browser può essere chiuso e non è nemmeno necessario che l'utente utilizzi attivamente la tua app web per interagire con la tua esperienza. La funzionalità richiede sia il service worker sia un file manifest dell'app web, sulla base di alcune delle funzionalità riassunte in precedenza.
L'API Push è implementata in Chrome, in fase di sviluppo in Firefox e in fase di valutazione in Edge. Al momento non sono disponibili indicatori pubblici da parte di Safari sulla sua intenzione di implementare questa funzionalità.
Notifiche push sul web aperto è un'introduzione completa alla configurazione delle notifiche push di Matt Gaunt. Inoltre, in Web Fundamentals è disponibile un codelab sulle notifiche push.
Se preferisci i video, Michael van Ouwerkerk del team di Chrome ha anche una presentazione di 6 minuti su Push.
Applicazione di funzionalità avanzate
Ricorda che la tua esperienza utente può avere diversi livelli di dolcezza a seconda del browser utilizzato per visualizzare la tua app web. Sei tu a controllare la copertura del caramello duro.
In questo modo, è possibile applicare alla tua app web progressive anche funzionalità aggiuntive che verranno implementate nella piattaforma web, come la sincronizzazione in background (per la sincronizzazione dei dati con un server anche quando l'app web è chiusa) e il Bluetooth web (per comunicare con i dispositivi Bluetooth dalla tua app web).
La sincronizzazione in background una tantum è stata attivata in Chrome e Jake Archibald ha realizzato un video della sua app Wikipedia offline e un articolo che la mostrano in azione. Se ti interessa provare l'API, François Beaufort ha anche una serie di esempi di Web Bluetooth disponibili.
Supporta i framework
Non c'è nulla che ti impedisca di applicare uno dei principi precedenti a un'applicazione o a un framework esistente con cui stai lavorando. Alcuni altri principi da tenere a mente durante la creazione della tua app web progressiva sono il modello di rendimento incentrato sull'utente RAIL e le animazioni basate su FLIP.
Mi auguro che nel corso del 2016 vedremo un numero crescente di boilerplate e progetti di seed che integreranno in modo organico il supporto delle Progressive Web App come funzionalità di base. Fino ad allora, la barriera per aggiungere queste funzionalità alle tue app non è molto alta e, a mio avviso, vale la pena fare lo sforzo.
Architettura
Esistono diversi livelli di "all-in" nel modello di app web progressive, ma un approccio comune è quello di strutturarle attorno a un shell dell'applicazione. Non si tratta di un requisito obbligatorio, ma offre diversi vantaggi.
L'architettura dell'involucro dell'applicazione incoraggia la memorizzazione nella cache dell'involucro dell'applicazione (l'interfaccia utente) in modo che funzioni offline e completi i contenuti utilizzando JavaScript. In caso di visite ripetute, ti consente di ottenere pixel significativi sullo schermo molto rapidamente senza la rete, anche se i tuoi contenuti provengono da lì. Ciò comporta un notevole aumento delle prestazioni.
Di recente Jeremy Keith ha commentato che in questo tipo di modello il rendering lato server non dovrebbe essere considerato un piano di riserva, ma il rendering lato client dovrebbe essere considerato un miglioramento. Questo è un feedback giusto.
Nel modello di shell dell'applicazione, il rendering lato server deve essere utilizzato il più possibile e il rendering progressivo lato client deve essere utilizzato come miglioramento nello stesso modo in cui "miglioriamo" l'esperienza quando il servizio worker è supportato. Esistono molti modi per affrontare questo problema.
Ti consiglio di leggere il nostro articolo sull'architettura e di valutare in che modo principi simili potrebbero essere applicati al meglio alla tua applicazione e al tuo stack.
Boilerplate di inizio
Shell dell'applicazione
Il repository app-shell
contiene un'implementazione quasi completa dell'architettura Application Shell. Ha un backend scritto in Express.js e un frontend scritto in ES2015.
Dato che copre sia le parti client sia quelle server del modello e che ci sono molte cose da fare, ci vuole un po' di tempo per acquisire familiarità con la base di codice. Al momento, è il nostro punto di partenza più completo per le app web progressive. La documentazione sarà il nostro prossimo obiettivo per questo progetto.
Starter kit per polimeri
Il punto di partenza ufficiale per le app web Polymer supporta le seguenti funzionalità delle app web progressive:
- Manifest dell'applicazione web
- Schermata iniziale di Chrome per Android
- Memorizzazione nella cache offline dei service worker con gli elementi SW Platinum
- Notifiche push (è necessaria la configurazione manuale) con gli elementi push di Platinum
Nella versione corrente di PSK non è supportato alcuni dei pattern di prestazioni più avanzati (ad es.il modello di shell dell'applicazione, il caricamento asincrono) che si trovano in alcune app web progressive in Polymer.
Abbiamo intenzione di provare a integrare questi pattern in PSK nel 2016, ma i primi esperimenti in merito sono disponibili nell'app Polymer Zuperkulblog di Rob Dodson e nell'eccellente talk Polymer Perf Patterns di Eric Bidelman.
Starter kit per il web
Il nostro punto di partenza per i nuovi progetti vanilla include le seguenti funzionalità delle app web progressive:
- Manifest dell'applicazione web
- Schermata iniziale di Chrome per Android
- Pre-memorizzazione nella cache dei service worker grazie a sw-precache
Se preferisci lavorare con JS/ES2015 standard e non riesci a utilizzare Polymer, Web Starter Kit può essere utile come punto di riferimento da cui riutilizzare o rubare snippet di codice.
App web progressive con e senza framework
I membri della community hanno già creato diverse app web progressive open source, sia con che senza librerie e framework JS. Se cerchi ispirazione, i repo riportati di seguito potrebbero esserti utili come riferimento. Sono anche app davvero ottime.
Vanilla JavaScript
- Memo vocali di Paul Lewis è realizzato utilizzando un'architettura simile a
app-shell
(report) - Wikipedia offline di Jake Archibald (video)
- Air Horner di Paul Kinlan
- Accordatore per chitarra di Paul Lewis (articolo)
Polymer
- Zuperkulblog di Rob Dodson (slide)
React
- iFixit di Jeff Posnick: utilizza
sw-precache
per la memorizzazione nella cache della shell dell'applicazione (slide)
Virtual-DOM
- Pokedex di Nolan Lawson: un'eccellente app web progressiva che applica un approccio "fai tutto in un web worker" per facilitare il rendering progressivo. (report)
Angular.js
- Timey.in di Kenneth Auchenberg: utilizza anche
sw-precache
per il pre-caching delle risorse
Note finali
Come accennato, le app web progressive sono ancora agli inizi, ma è un momento entusiasmante per sperimentare le metodologie alla base e capire quanto bene possono essere applicate alle tue app web.
Paul Kinlan sta attualmente pianificando le indicazioni di Web Fundamentals sulle app web progressive. Se hai suggerimenti sulle aree che vorresti che fossero trattate, non esitare a commentare il thread.
Per approfondire
- App web progressive: sfuggire alle schede senza perdere la nostra anima
- Perché le app web progressive sono il futuro dello sviluppo web
- App web progressive: pronte per il grande pubblico
- Creare un'app progressiva con ServiceWorker
- Le app web progressive sono il futuro
- App web progressiva: un nuovo modo di utilizzare i dispositivi mobili
- Presentazione di Pokedex.org: un'app web progressiva per i fan dei Pokémon
- Riepilogo del Chrome Developer Summit: app web progressive