Pubblicare immagini adattabili

Katie Hempenius
Katie Hempenius

Per pubblicare immagini di formato desktop sui dispositivi mobili potrebbe essere utilizzata una quantità di dati 2-4 volte maggiore rispetto necessaria. Segui le linee guida in questa pagina per migliorare l'esperienza utente pubblicare immagini di dimensioni diverse per dispositivi diversi.

Immagini adattabili e Core Web Vitals

Quando pubblichi immagini adattabili, la pagina valuta le funzionalità di visualizzazione del dispositivo dell'utente e scegliendo una di una serie di immagini candidati che sono ottimale per la visualizzazione in base a questi criteri. In questo modo vengono salvati i dati degli utenti, principalmente pubblicando immagini più piccole su dispositivi con schermi più piccoli.

Gli effetti di un caricamento più rapido delle immagini possono anche estendersi LCP (Largest Contentful Paint). Ad esempio, se la tua pagina L'elemento LCP è un'immagine che pubblica può ridurre la durata del carico delle risorse in modo reattivo.

Una durata del carico delle risorse inferiore riduce il tempo di caricamento di un'immagine LCP, migliorando la tua il punteggio LCP della pagina. Con un LCP più basso gli utenti vedranno che il sito viene caricato più velocemente, soprattutto quando i contenuti più importanti (l'elemento LCP) vengono caricati più rapidamente. La pubblicazione di immagini reattive può anche ridurre il conflitto di larghezza di banda per altre risorse sulla pagina, che possono migliorare la velocità di caricamento generale della pagina.

Ridimensiona immagini

Due degli strumenti di ridimensionamento più diffusi sono il pacchetto npm Sharp e lo strumento dell'interfaccia a riga di comando ImageMagick.

Il pacchetto nitido è una buona scelta per automatizzare il ridimensionamento delle immagini (ad esempio, generando miniature di diverse dimensioni per tutti i video del tuo sito web). it è veloce e si integra bene con gli strumenti e gli script di build. ImageMagick è più pratico per il ridimensionamento di immagini una tantum perché viene eseguito interamente dal comando dalla riga di comando.

forte

Per utilizzare Sharp come script Node, salva questo codice come script separato nel progetto, quindi eseguilo per convertire le immagini:

const sharp = require('sharp');
const fs = require('fs');
const directory = './images';

fs.readdirSync(directory).forEach(file => {
  sharp(`${directory}/${file}`)
    .resize(200, 100) // width, height
    .toFile(`${directory}/${file}-small.jpg`);
  });

ImageMagick

Per ridimensionare un'immagine al 33% della sua dimensione originale, esegui il comando seguente in il tuo terminale:

convert -resize 33% flower.jpg flower-small.jpg

Per ridimensionare un'immagine in modo che rientri in uno spazio di 300 px di larghezza per 200 px di altezza, esegui la seguente comando:

# macOS/Linux
convert flower.jpg -resize 300x200 flower-small.jpg

# Windows
magick convert flower.jpg -resize 300x200 flower-small.jpg

Quante versioni delle immagini dovresti creare?

Non esiste un solo "corretto" a questa domanda. Tuttavia, capita spesso e pubblicare da 3 a 5 dimensioni diverse di un'immagine. Pubblicare più dimensioni delle immagini è più adatto ma occupa più spazio sui server e richiede la scrittura leggermente più HTML.

Altre opzioni

Servizi di immagini come Thumbor (open source) e Cloudinary. Entrambi sono modi semplici per creare immagini adattabili che forniscano anche la manipolazione del modello on demand. Per configurare Thumbor, installalo sul tuo server. Cloudinario si occupa dei dettagli al posto tuo e non richiede alcuna configurazione del server.

Pubblica più versioni delle immagini

Quando specifichi più versioni dell'immagine, il browser sceglie quella migliore per usa:

Prima Dopo
<img src="fiore-large.jpg"> <img src="fiore-grande.jpg" srcset="flower-small.jpg 480 s, fiore-grande.jpg 1080w" dimensioni="50vw">

Il tag <img> src, srcset, e sizes tutti gli attributi interagiscono per raggiungere questo risultato finale.

L'attributo "SRC" attributo

L'attributo src consente il funzionamento di questo codice per i browser che non supportano i srcset e sizes attributi. Questi browser ricorrono al caricamento della risorsa specificata Attributo src.

L'elemento "srcset" attributo

L'attributo srcset è un elenco separato da virgole di nomi file di immagini e relativi di larghezza o densità.

Questo esempio utilizza descrittori di larghezza, che indicano al browser la larghezza di un'immagine in modo che non sia necessario scaricare un'immagine per scoprirlo. 480w è un descrittore di larghezza indica al browser che flower-small.jpg è larga 480 px. 1080w è un descrittore di larghezza che indica browser che flower-large.jpg sia largo 1080 px.

Credito aggiuntivo: Non è necessario conoscere i descrittori di densità per pubblicare immagini di dimensioni diverse. Tuttavia, se ti interessa sapere come funzionano i descrittori di densità, dai un'occhiata alla Lab sul codice relativo al passaggio della risoluzione. I descrittori di densità vengono utilizzati per pubblicare immagini diverse in base al densità di pixel.

Le "dimensioni" attributo

L'attributo dimensioni indica al browser quanto sarà larga l'immagine quando è visualizzato, anche se questo non influisce sulle dimensioni di visualizzazione dell'immagine, quindi devi comunque CSS.

Il browser utilizza queste informazioni, insieme alle informazioni in suo possesso sulla dispositivo (incluse dimensioni e densità in pixel) per stabilire quale immagine caricamento.

Se un browser non riconosce "sizes" , utilizza l'attributo caricamento dell'immagine specificata dal "src" . (sizes e srcset contemporaneamente, pertanto ogni browser supporta attributi o nessuno dei due.)

Credito aggiuntivo: Se vuoi essere fantasioso, puoi utilizzare anche l'attributo dimensioni per specificare in più dimensioni dell'area annuncio. È compatibile con i siti web che utilizzano layout diversi per diverse dimensioni dell'area visibile. Guarda questo esempio di codice per più slot per scoprire come fare.

(Ancora più) Crediti extra

Oltre a tutto il merito aggiuntivo già elencato (le immagini sono complesse), puoi usare gli stessi concetti direzione artistica. La direzione artistica è la pratica di pubblicare immagini dall'aspetto completamente diverso (invece di versioni diverse della stessa immagine) in aree visibili diverse. Tu Per saperne di più, consulta il lab sul codice Art Direction.

Verifica

Dopo aver implementato le immagini adattabili, puoi usare Lighthouse per assicurarti non hai perso nessuna immagine. Esegui il controllo delle prestazioni di Lighthouse (Lighthouse > Opzioni > Prestazioni) e cerca i risultati delle Controllo Dimensioni corrette delle immagini. Questi risultati elencano le immagini che devi ancora ridimensionare.