HTML5

linguaggio di markup per realizzare pagine web

HTML5 è la quinta versione del linguaggio di formattazione HTML raccomandata dal World Wide Web Consortium,[1] distribuita a partire dall'ottobre 2014 e concepita per definire standard funzionali (es. riproduzione audio/video) e API.

HTML 5
linguaggio di programmazione
AutoreTim Berners Lee
Data di origine1989
Ultima versioneHTML5
UtilizzoProgrammazione dei siti WEB
TipizzazioneForte
Estensioni comunihtml e htm
Implementazione di riferimento
Sistema operativoWindows, macOS, Android, iOS, Linux.
LicenzaOpen Source
Sito webhtml.spec.whatwg.org/multipage/

Storia modifica

Lo sviluppo venne avviato dal gruppo di lavoro WHATWG, fondato nel 2004 da sviluppatori appartenenti ad Apple, Mozilla Foundation e Opera Software. L'obiettivo era la progettazione delle specifiche per lo sviluppo di applicazioni web, con particolare attenzione per i miglioramenti da apportare sia ad HTML che alle tecnologie correlate.

Inizialmente in contrasto con il World Wide Web Consortium per le lungaggini nel processo di evoluzione dello standard html e per la decisione del W3C di orientare la standardizzazione verso l'XHTML 2 che non garantiva retro compatibilità, lo stesso W3C ha poi riconosciuto valide tali motivazioni, annunciando di creare un apposito gruppo per la standardizzazione dell'HTML5 e abbandonare l'XHTML 2.0[2].

Dal 2007 il WHATWG ha collaborato con il W3C in tale processo di standardizzazione, per poi decidere nel 2012 di separarsi dal processo di standardizzazione del W3C[3], creando di fatto due versioni dell'HTML5: la versione del WHATWG viene definita come "HTML Living Standard" e quindi in continua evoluzione, mentre quella del W3C sarà un'unica versione corrispondente ad uno "snapshot" del Living Standard.

La prima Candidate Recommendation è stata pubblicata dal W3C il 17 dicembre 2012, e la prima versione dello standard è stata pubblicata come Recommendation il 28 ottobre 2014.

La versione HTML 5.1 è stata pubblicata dal W3C come Recommendation il 1º novembre 2016.

La versione HTML 5.2 è stata pubblicata dal W3C come Recommendation il 14 dicembre 2017[4]

La versione HTML 5.3 è stata pubblicata dal W3C come Recommendation il 28 gennaio 2021.[5]

Tag deprecati modifica

HTML5 ha deprecato i seguenti tag e attributi presenti in HTML4 poiché la loro funzione è ora gestita dai CSS3[6]:

 
Elementi HTML4 deprecati in HTML5

CSS3 modifica

  Lo stesso argomento in dettaglio: CSS.

HTML5 e CSS3 (l'evoluzione di CSS2) costituiscono un linguaggio turing completo[7][8], condizione sufficiente per un linguaggio per essere considerato un linguaggio di programmazione.

SEO modifica

  Lo stesso argomento in dettaglio: Ottimizzazione per i motori di ricerca.

HTML5 è progettata per migliorare la SEO rispetto alle versioni precedenti di HTML.

Supporto dei browser modifica

 
Esempio di una pagina HTML5 in Internet Explorer 7. Essa appare sfasata poiché il browser non riconosce le specifiche

Alla nascita di HTML5 il motore di rendering Webkit (Chrome e Safari) fu il primo a interpretare in modo corretto molti dei nuovi codici, il secondo ad aggiornarsi da quel punto di vista fu Gecko (Firefox) e per ultimo Trindent (Internet Explorer). Per alcuni anni i siti web che utilizzavano i nuovi tag HTML disponibili venivano visti in maniera differente a seconda del browser che utilizzava l'utente[9]. In parte questo problema veniva risolto da tecniche come CSS alternativi appositamente per Internet Explorer, commenti condizionali su misura per esso e librerie JavaScript come Modernizr[10][11][12]. Dal 2019 Microsoft Edge supporta la maggior parte delle specifiche HTML5[13].

Novità modifica

  Lo stesso argomento in dettaglio: WebGL, Canvas (elemento HTML), Scalable Vector Graphics e HTML5 video.

Le novità introdotte dall'HTML5 rispetto all'HTML4 sono finalizzate soprattutto a migliorare il disaccoppiamento fra struttura, definita dal markup, caratteristiche di resa (tipo di carattere, colori, eccetera), definite dalle direttive di stile, e contenuti di una pagina web, definiti dal testo vero e proprio. Inoltre l'HTML5 prevede il supporto per la memorizzazione locale di grandi quantità di dati scaricati dal web browser, per consentire l'utilizzo di applicazioni basate su web (come per esempio le caselle di posta di Google o altri servizi analoghi) anche in assenza di collegamento a Internet.

In particolare[14]:

  • vengono rese più stringenti le regole per la strutturazione del testo in capitoli, paragrafi e sezioni;
  • vengono introdotti elementi di controllo per i menu di navigazione;
  • vengono migliorati ed estesi gli elementi di controllo per i moduli elettronici, cioè nuovi attributi e tipi di input per i form (moduli di iscrizione e contatto);
  • vengono introdotti elementi specifici per il controllo di contenuti multimediali (tag <video> e <audio>), con HTML4 incorporabili solo attraverso Adobe Flash.
  • vengono estesi a tutti i tag una serie di attributi, specialmente quelli finalizzati all'accessibilità (WAI-ARIA), finora previsti solo per alcuni tag;
  • viene supportato Canvas che permette di utilizzare JavaScript per creare animazioni (possibili solo con Adobe Flash ai tempi di HTML4) e grafica bitmap;
 
Un esempio di HTML5 Storage. L'utente può creare note e, anche in caso di refresh del browser, esse rimarranno salvate[15].
  • introduzione della geolocalizzazione, dovuta ad una forte espansione di sistemi operativi mobili (quali Android e iOS, tra i più diffusi);
  • sistema alternativo ai normali cookie, chiamato Web Storage, più efficiente, il quale consente un notevole risparmio di banda;
  • standardizzazione di programmi JavaScript, chiamati Web Workers e possibilità di utilizzare alcuni siti offline;
  • sostituzione del lungo e complesso doctype, con un semplice <!DOCTYPE html>.
  • Nuovi microdati che descrivono il contenuto dei tag (ad esempio se è un nome, un cognome, un indirizzo, un numero di telefono, una mail eccetera);
  • WebSocket API: la possibilità di stabilire e mantenere una connessione dati tra browser e server remoto sulla quale far transitare messaggi in entrambe le direzioni;
  • Drag and Drop (trascinamento e rilascio di oggetti all'interno di un contenitore, ad esempio nel caso di videogiochi o prodotti da inserire nel carrello nei siti ecommerce);
  • SVG e MathML: possibilità di inserire in HTML grafica vettoriale e formule matematiche, le quali in HTML4 potevano essere importate solo come immagini o creabili in Adobe Flash.
TAG[14] SCOPO
Nuovi elementi strutturali e semantici
Header
 
Confronto tra pagina di base HTML4 e 5
Footer
Section
Nav
Article (nel caso di articoli in homepage)
Aside (contenuti correlati al principale)
Hgroup Raggruppa i tag Heading
<figure> e <figcaption> Didascalie per contenuti
Embed Inserisce contenuti interattivi o multimediali
Ruby Specifica le annotazioni Ruby
Wbr Il browser può inserire un a capo
<command> e <menu> Definiscono barre degli strumenti o menu di scelta rapida
<details> e <summary> Widget informativi per gli utenti
mark Parte di un testo segnato o evidenziato all'utente
<time> e attributi pubdate e datetime Tempo su 24 ore o una data nel calendario Gregoriano
Meter Misura scalare di un intervallo noto o un valore frazionario
Progress Stato di completamento di un compito
Picture Contenitore per immagini
Microdati Per ogni tag HTML si possono specificare degli attributi semantici
Nuovi attributi e tipi di input per i form
autofocus, placeholder e form
 
L'autofocus in questo caso è in rosso. Gli input type equivalgono agli spazi da riempire (in questo caso c'è "email"). Il placeholder è il testo di esempio di ogni spazio
Input type: tel
Input type: search
Input type: url
Input type: email
Input type: number
Input type: range
Input type: color
Datalist Completamento automatico ad un elemento del form
Autocomplete Permette o no al browser di riempire i campi

del form in maniera automatica

Min, max Definiscono il valore minimo e massimo consentito
Multiple Permette all’utente possa inserire più valori per lo stesso input
Pattern Verifica che il valore inserito rispetti determinate regole
Required Rende obbligatoria la compilazione di uno spazio del form
Step Definisce la distanza che intercorre tra un valore e il successivo
keygen Generatore di chiavi numeriche all’interno di un form
output Restituisce il risultato di un calcolo
API per Web Applications
Applicazioni web offline (file ".manifest") Dopo la prima sessione di navigazione online,

resteranno accessibili alcuni oggetti anche

in assenza di una connessione di rete.

Indexed Database API Creare e manipolare un database all’interno del browser
WebStorage API Si possono ad esempio tenere aperti contemporaneamente

due account social o mail sullo stesso browser e ogni navigazione

sul primo comporterà il logout del secondo e viceversa

Web Workers API Consentono l’esecuzione di pezzi di codice Javascript

senza intaccare le performance della pagina web

WebSocket API Stabiliscono e mantengono una connessione dati tra browser

e server remoto sulla quale far transitare messaggi

in entrambe le direzioni

Drag and Drop Trascinamento e rilascio di oggetti
Geolocation API Geolocalizzazione
Multimedia
SVG e MathML Immagini vettoriali e formule matematiche
Canvas/WebGL API adatte a tracciare linee, cerchi, rettangoli, immagini e oggetti 3D
Video Inserisce file video (prima fattibile solo con Adobe Flash)
Audio Inserisce file audio

WAI ARIA modifica

  Lo stesso argomento in dettaglio: Accessibilità (web), Accessibilità (design) e Wai-aria.

WAI-ARIA (Web Accessibility Initiative - Accessible Rich Internet Applications) è un insieme di documenti pubblicati dal W3C (World Wide Web Consortium) che specificano come aumentare l'accessibilità dei contenuti dinamici e dei componenti per l'interfaccia utente sviluppati con AJAX, HTML, JavaScript e altre tecnologie collegate. HTML5 ha aggiunto nuove regole WAI ARIA[16].

Orientamento del dispositivo modifica

 
Esempio di deviceorientation e devicemotion

L'eventodeviceorientationviene generato quando sono disponibili nuovi dati da un sensore di orientamento sull'orientamento corrente del dispositivo rispetto al riquadro delle coordinate terrestri. Questi dati vengono raccolti da un magnetometro all'interno del dispositivo. In pratica, quando si ruota il dispositivo su cui la pagina web viene visualizzata, l'oggetto che contiene questa API ruota in base all'asse x, y o z del dispositivo[17][18].

Codice base:

window.addEventListener('deviceorientation', function(event) {
  var a = event.alpha;
  var b = event.beta;
  var g = event.gamma;
}, false);

Movimento modifica

Gli eventi di movimento vengono gestiti allo stesso modo degli eventi di orientamento, tranne per il fatto che hanno il proprio nome di evento: devicemotion[19][20].

Esempio:

window.addEventListener("devicemotion", handleMotion, true);

Rispetto a deviceorientation le informazioni fornite all'interno dell'oggetto DeviceMotionEventdiventano parametri della funzione HandleMotion.

L'evento di movimento contiene quattro proprietà:

  • DeviceMotionEvent.acceleration
  • DeviceMotionEvent.accelerationIncludingGravity
  • DeviceMotionEvent.rotationRate
  • DeviceMotionEvent.interval

Valori di movimento modifica

Gli oggettiDeviceMotionEventforniscono informazioni sulla velocità dei cambiamenti della posizione e dell'orientamento del dispositivo. Le modifiche vengono fornite lungo tre assi[21].

Per acceleratione accelerationIncludingGravity tali assi corrispondono a:

  • x: Rappresenta l'asse da Ovest a Est
  • y: Rappresenta l'asse da Sud a Nord
  • z: Rappresenta l'asse perpendicolare al suolo

Per rotationRate le informazioni corrispondono a:

  • alpha: Rappresenta una velocità di rotazione lungo l'asse perpendicolare al dispositivo.
  • beta: Rappresenta una velocità di rotazione lungo l'asse che va da sinistra a destra del dispositivo.
  • gamma: Rappresenta una velocità di rotazione lungo l'asse che va dal basso verso l'alto del dispositivo.

intervalrappresenta l'intervallo di tempo, in millisecondi, in cui i dati vengono ottenuti dal dispositivo.

HTML5test modifica

 
Pagina di HTML5test vista nel browser Chrome

HTML5test è un'applicazione web per valutare l'accuratezza di un browser web nell'implementazione degli standard web HTML5 e Web SQL Database (sviluppato dal World Wide Web Consortium), così come lo standard WebGL (sviluppato da Mozilla Foundation e Khronos Group)[22].

La suite di test è stata sviluppata dal programmatore web olandese Niels Leenheer e pubblicata nel marzo 2010. Per testare un browser web, l'utente deve visitare la home page del sito web che si trova all'indirizzo html5test.com[23]. L'applicazione restituisce un punteggio intero su un massimo di 555 punti. Il totale dei punti è cambiato più volte attraverso l'evoluzione del software; Leenheer ha introdotto successivamente un sistema di punteggio come parte di un'importante riprogettazione del test introdotta nel novembre 2013[24].

HTML5test valuta il supporto del browser per l'archiviazione Web, l'API di geolocalizzazione W3C, gli elementi HTML specifici per HTML5 (incluso l'elemento Canvas) e altre funzionalità[25][26]. Non valuta la conformità di un browser ad altri standard web, come Cascading Style Sheets, ECMAScript, Scalable Vector Graphics o Document Object Model. I test di conformità per questi standard sono di competenza di Acid3, un test automatizzato pubblicato da Ian Hickson nel 2008[27]. Allo stesso modo, Acid3 non valuta la conformità HTML5 di un browser. L'ambito del test di HTML5test e l'ambito del test di Acid3 si escludono a vicenda.

Esempi modifica

Note modifica

  1. ^ (EN) Browser vendors win war with W3C over HTML and DOM standards, su ZDNET. URL consultato l'8 novembre 2023.
  2. ^ (EN) XHTML 2 Working Group Expected to Stop Work End of 2009, W3C to Increase Resources on HTML5, su w3.org, World Wide Web Consortium. URL consultato il 15 febbraio 2011.
  3. ^ (EN) Update on the relationship between the WHATWG HTML living standard and the W3C HTML5 specification, su lists.w3.org, World Wide Web Consortium. URL consultato il 22 luglio 2012.
  4. ^ https://www.w3.org/TR/html52/ HTML 5.2 W3C Recommendation
  5. ^ https://www.w3.org/TR/html53/ HTML 5.3 W3C Recommendation
  6. ^ (EN) HTML Tags Which Are Deprecated In HTML5, su c-sharpcorner.com. URL consultato il 3 febbraio 2021.
  7. ^ Stupid Machines - rule 110, su github.com.
  8. ^ Rule 110 OnLine Demonstration, su eli.fox-epste.in.
  9. ^ (EN) Getting to Grips with HTML5 Browser Compatibility, su Speckyboy Design Magazine, 26 marzo 2012. URL consultato il 3 febbraio 2021.
  10. ^ Css3 su Internet Explorer 8? - da oggi si può, su Target Web.it, 8 aprile 2011. URL consultato il 3 febbraio 2021.
  11. ^ (EN) Internet Explorer Conditional Comments - SitePoint, su sitepoint.com. URL consultato il 3 febbraio 2021.
  12. ^ Faruk Ateş, Approfittare di HTML5 e CSS3 con Modernizr, su Italian A List Apart, 5 luglio 2010. URL consultato il 3 febbraio 2021.
  13. ^ HTML5test - How well does your browser support HTML5?, su html5test.com. URL consultato il 3 febbraio 2021.
  14. ^ a b HTML5: guida completa, su HTML.it. URL consultato il 29 gennaio 2021.
  15. ^ Create a Sticky Note Effect in 5 Easy Steps With CSS3 and HTML5, su Code Envato Tuts+. URL consultato l'8 ottobre 2021.
  16. ^ (EN) Accessible Rich Internet Applications (WAI-ARIA) 1.1, su w3.org. URL consultato il 22 febbraio 2021.
  17. ^ (EN) Window: deviceorientation event - Web APIs | MDN, su developer.mozilla.org. URL consultato l'8 ottobre 2021.
  18. ^ DeviceOrientation Event Specification, su w3.org. URL consultato l'8 ottobre 2021.
  19. ^ Sandro Paganotti, HTML5 Device Orientation API e WebSocket, su HTML.it. URL consultato l'8 ottobre 2021.
  20. ^ (EN) Using Device Orientation in HTML5 - SitePoint, su sitepoint.com. URL consultato l'8 ottobre 2021.
  21. ^ Sandro Paganotti, Video: HTML5, DeviceOrientation & WebSocket API, su HTML.it. URL consultato l'8 ottobre 2021.
  22. ^ Niels Leenheer, HTML5test Frequently Asked Questions, su HTML5test.com, Niels Leenheer. URL consultato il 10 luglio 2014.
  23. ^ Martin Brinkmann, HTML5 Test Your Web Browser, su gHacks Technology News. URL consultato il 10 luglio 2014.
  24. ^ Niels Leenheer, The new HTML5test is here!, su blog.html5test.com, 13 novembre 2013. URL consultato il 12 luglio 2014.
  25. ^ Staff writer, Test Your Browser for HTML5 Compatibility, su CyberNet News. URL consultato il 10 luglio 2014.
  26. ^ Erez Zukerman, Test your browser's HTML5 prowess with the HTML5 test, su Switched, AOL, 8 agosto 2010. URL consultato il 10 luglio 2014 (archiviato dall'url originale il 26 aprile 2019).
  27. ^ Acid3: Putting Browser Makers on Notice, Again., su webstandards.org, Web Standards Project, 3 marzo 2008. URL consultato il 10 luglio 2014.

Bibliografia modifica

  • Jeffrey Zeldman, Ethan Marcotte, Sviluppare siti con gli standard web, Milano, Apogeo, 2010, ISBN 978-88-503-2964-9.
  • Mark Pilgrim, HTML5: Guida operativa, Milano, Hops Tecniche nuove, 2010, ISBN 978-88-481-2504-8.
  • Gabriele Gigliotti, HTML5: Sviluppare oggi il Web di domani, Milano, Apogeo, 2012, ISBN 978-88-503-3116-1.

Voci correlate modifica

Altri progetti modifica

Collegamenti esterni modifica

Controllo di autoritàGND (DE7704810-6