HTML 5 e CSS 3: UN CONNUBIO VINCENTE PER LA ...

15 downloads 520 Views 2MB Size Report
UNIVERSITA' DEGLI STUDI DI PADOVA. FACOLTA' DI INGEGNERIA. CORSO DI LAUREA TRIENNALE IN INGEGNERIA INFORMATICA. HTML 5 e CSS 3: UN  ...
UNIVERSITA’ DEGLI STUDI DI PADOVA FACOLTA’ DI INGEGNERIA CORSO DI LAUREA TRIENNALE IN INGEGNERIA INFORMATICA

HTML 5 e CSS 3: UN CONNUBIO VINCENTE PER LA PROGRAMMAZIONE WEB DI DOMANI

RELATORE: CH.MO PROF. MICHELE MORO LAUREANDO: FEDERICO TOFFANO ANNO ACCADEMICO: 2011-2012

1

INDICE

INDICE ................................................................................................................................... 1 SOMMARIO ........................................................................................................................... 3 1 INTRODUZIONE .................................................................................................................. 4 2 SEMANTICA ........................................................................................................................ 6 3 WEB FORMS 2.0 ................................................................................................................ 12 4 VIDEO E AUDIO CON HTML 5 ............................................................................................ 19 5 CANVAS ............................................................................................................................ 22 6 MICRODATA ..................................................................................................................... 27 7 APPLICAZIONI WEB OFFLINE ............................................................................................. 29 8 WEB STORAGE .................................................................................................................. 32 9 GEOLOCALIZZAZIONE ........................................................................................................ 35 10 LE ALTRE API DI HTML 5 .................................................................................................. 38 11 NUOVI SELETTORI E PSEUDO-CLASSI ............................................................................... 39 12 WEB FONTS..................................................................................................................... 47 13 EFFETTI TIPOGRAFICI ...................................................................................................... 49 14 BORDI E SFONDI ............................................................................................................. 53 15 TRASFORMAZIONI .......................................................................................................... 59 16 TRANSIZIONI E ANIMAZIONI ........................................................................................... 63 17 UN ESEMPIO PRATICO .................................................................................................... 67 CONCLUSIONI ...................................................................................................................... 70 RIFERIMENTI BIBLIOGRAFICI ................................................................................................ 71

2

Sommario Il principale obiettivo di questa tesi è di documentare le maggiori novità introdotte dai linguaggi HTML 5 e CSS 3. Per una giusta comprensione è necessaria una discreta conoscenza di HTML 4 e CSS 2 ed inoltre essere al corrente delle basilari potenzialità di javaScript: nel prosieguo queste conoscenze si danno per assunte. Saranno analizzati nel dettaglio i nuovi elementi di HTML 5, le proprietà di CSS 3, saranno descritte alcune funzioni JavaScript di supporto a queste due nuove tecnologie, ci saranno alcuni esempi di codice con l’intenzione di valutare alcune delle nuove funzionalità, e infine le tabelle di compatibilità dei vari elementi relative ai browser più popolari. Per verificare se una data proprietà è supportata o no dai vari browser, si può utilizzare un servizio come When can I use fruibile dal sito http://caniuse.com/. Alternativamente le varie funzionalità sono consultabili in modo rapido e intuitivo dal sito web http://html5readiness.com/ tramite un’infografica dinamica. Per vedere l’effetto degli esempi riportati si può utilizzare un editor HTML online come http://rendera.heroku.com/.

3

1 INTRODUZIONE Con l’evoluzione di HTML, acronimo di Hyper Text Markup Language (linguaggio di marcatura per ipertesti) e di CSS (fogli di stile o Cascading Style Sheets), il World Wide Web si sta trasformando in un ambiente dove i documenti caricati sono associati ad informazioni e dati facilitando così l'interrogazione e l'interpretazione dei contenuti. Questa evoluzione s’indica con il termine web semantico coniato da Tim Berners-Lee fondatore del www assieme a Robert Cailliau. A causa delle divergenze ideologiche tra il W3C e il WAHTWG (i due enti coinvolti nella definizione della specifica) e i diversi interessi delle aziende coinvolte nello sviluppo dei principali browser, HTML 5 adotta alcune scelte che possono sembrare discutibili ma sono frutto di sano pragmatismo.

Perché HTML 5 e CSS 3? Quando sono state definite le precedenti versioni, il web era strettamente collegato al concetto di ipertesto: gli utenti lo utilizzavano con il principale obbiettivo di ottenere informazioni tipicamente in forma testuale. Inoltre la velocità di connessione era mediamente bassa e di conseguenza applicazioni web quali quelle odierne erano impensabili. L’obbiettivo principale era quello di pubblicare semplici documenti testuali collegati fra loro. Negli anni successivi il numero di utenti è cresciuto molto rapidamente e questo ha permesso investimenti per aumentare le velocità di connessione e quindi lo sviluppo di applicazioni web più complesse. Le specifiche però non erano adatte a questo nuovo utilizzo del web, quindi molti sviluppatori si sono visti costretti ad aggirare le limitazioni imposte con metodologie spesso complesse e poco eleganti. Queste due nuove tecnologie nascono per offrire un supporto a questo nuovo mondo del web sia per quanto riguarda la strutturazione del contenuto, sia per lo sviluppo di vere e proprie applicazioni web. Il World Wide Web Consortium ha annunciato che la prima versione dello standard HTML 5 è pronta per il luglio 2014. CSS 3, rispetto alle versioni precedenti, adotta un approccio modulare. Ciascun modulo quindi copre determinate specifiche, di conseguenza il ciclo di vita e l’avanzamento è diverso per ognuno di essi.

Privacy Con l’avvenire di HTML 5 e delle novità ad esso collegate, come il Web Storage e la geolocalizzazione, il tema della privacy è sempre più sensibile. Gli utenti che utilizzeranno questi strumenti condivideranno informazioni riguardanti i loro interessi e le loro attitudini in modo nettamente superiore rispetto alle informazioni che lasciamo in rete oggi.

Flash vs HTML 5 Dopo numerose battaglie tra le due tecnologie, Adobe ha annunciato ufficialmente che non svilupperà più Flash per dispositivi mobili, Flash Player 11 sarà l'ultima versione ufficiale rilasciata per dispositivi mobili e il futuro sarà HTML 5.

4

Steve Jobs, in una lettera aperta intitolata “Thoughts on Flash” del 2010, spiega quali sono i motivi che hanno portato Apple ad optare per HTML 5 preannunciando un futuro senza il software di Adobe per quanto riguarda le animazioni nel campo mobile. Forse il contributo al decadimento di questa tecnologia, per quanto riguarda i dispositivi mobili, in parte è da attribuire proprio alla campagna di pubblicità negativa dettata da Apple. Basti pensare che IPhone e Ipad non supportano tale tecnologia. Inoltre anche Microsoft, YouTube, Amazon e molte altre aziende stanno migrando verso la nuova tecnologia HTML. Oltre alla pubblicità negativa, HTML 5, rispetto a Flash, offre un linguaggio per le animazioni molto più leggero ed è supportato da tutti i browser moderni. Attualmente HTML 5 non è ancora in grado di rimpiazzare completamente Flash ma ha il vantaggio rendere la Rete libera e non dipendente da tecnologie proprietarie. Probabilmente in futuro, anche tramite l’utilizzo di librerie JavaScript, HTML 5 sarà in grado di rimpiazzare completamente Flash.

JavaScript Durante questa fase di transazione rivolta verso le nuove specifiche, si sono diffuse alcune librerie JavaScript per dare un supporto alle nuove tecnologie: 





Testare la capacità o meno dei vari browser di elaborare correttamente le nuove funzionalità: Modernizr è una di queste, lo scopo è verificare il funzionamento di determinate funzioni indipendentemente dal browser utilizzato. Sostituire le funzionalità del browser mancanti con altre funzioni: la libreria excanvas creata da Google, ad esempio, permette l’utilizzo dell’elemento sulle versioni di Internet Explorer precedenti alla 9. Effetti grafici: queste librerie evidenziano le potenzialità di questa innovazione, un esempio potrebbe essere la libreria close-pixelate di David De Sandro.

Retrocompatibilità Innanzitutto per utilizzare le nuove specifiche bisogna adottare una strategia di retrocompatibilità nel caso in cui queste non siano supportate. Una strategia potrebbe essere quella di identificare il browser utilizzato e la sua versione nel momento in cui si visualizza una pagina web e prendere decisioni in funzione del risultato. Una strategia migliore prevede l’utilizzo della libreria JavaScript Modernizr che esegue rapidamente una serie di test per stabilire se una data funzionalità sia supportata o meno. Test retrocompatibilià con Modernizr if(Modernizr.video()) { /*supportato*/ } else { /*non supportato: strategie alternative*/ }

Video è una proprietà booleana dell’oggetto Modernizr, se il suo valore è true allora il browser supporterà l’elemento . 5

2 Semantica Con semantica di un tag s’intende il significato che l’elemento attribuisce al suo contenuto. Con le nuove specifiche di HTML 5 gli attributi stilistici vengono gestiti solamente tramite fogli di stile in modo tale da separare il contenuto di un documento dalla sua visualizzazione.

Doctype Il doctype è il primo elemento che dovrebbe comparire in un documento HTML. La sua funzione è di validare il documento e, per alcuni browser, serve ad abilitare la modalità di interpretazione standard. Doctype HTML 5

Doctype HTML 4.01 strict

Inserire il doctype di HTML 4 come si può ben vedere non era per niente semplice. Fortunatamente con la nuova specifica la sintassi di questo elemento è molto più snella.

Codifica dei caratteri Nell’intestazione di un documento HTML (all’interno dei tag ) sono definiti i tag tra i quali uno è utilizzato per definire la codifica dei caratteri. Codifica caratteri HTML 5