HTML5 – Den enda versionen av HTML du behöver

HTML5
Den enda versionen av HTML du behöver
Emil Stenström – Suniweb 2010
@EmilStenstrom
emil.stenstrom@valtech.se
Approach
• HTML5 är både stort, och luddigt
• Vi har 45 minuter på oss
• Era frågor får styra vad jag berättar om
Varför använder ni inte redan HTML5?
HTML5
• Vad ingår i HTML5?
• Ny och ändrad HTML
• Javascript API:er med
exempelkod
• Argument för HTML5
• Hur gör man?
•
•
•
•
Tillgänglighet
Sökmotorer
Bakåtkompatibilitet
Vad händer med
XHTML?
Vad ingår i HTML5?
• Massor
• 300.000 ord (vs. 100.000 ord i HTML4)
• 160.000 ord för webbutvecklare
•
•
•
•
•
Specifikation av parsning
Uppdatering av taggar och attribut
~15 nya JavaScript-API:er
Förhållandet till XHTML
Idé om bakåt- och framåtkompatibilitet
Parsning av HTML
• HTML4 saknar
•
•
•
parsningsinstruktioner
HTML5 har hela
algoritmen i spec:en
Kommer med
referensimplementation:
http://html5.validator.nu
Byggd tillsammans med
alla webbläsartillverkare
Vad är korrekt HTML5?
•
•
•
•
<DIV>A monkey</DIV>
<p id=john>John's P</p>
<InPuT type="text">
<input type="text" />
• Japp, allt det är korrekt.
Uppdatering av tillåtna taggar
•
•
•
•
•
Ny Doctype
Nya taggar
Ändrade taggar
Borttagna taggar
Nya attribut
Ny doctype
• <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML
4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">
• <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0
Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1strict.dtd">
• <!doctype html>
Nya taggar
•
•
•
•
•
•
•
•
•
•
section
article
aside
hgroup
header
footer
nav
figure
figcaption
...
Generell avdelning. Används med hX.
Oberoende del av dokumentet
Innehåll med svag koppling till resten
En rubrik, som kan innehålla flera hX
Avdelning för introduktion/navigation
Avdelning för författare/copyright
Del av sidan med navigation i
Oberoende atomärt innehåll
Valfri beskrivningstext till figure
Nya taggar
•
•
•
•
•
•
•
•
•
video
audio
embed
mark
progress
meter
time
ruby/rt/rp
...
Videouppspelning utan plugin
Ljuduppspelning utan plugin
För att starta plugins. Ej tidigare spec:ad
Text som är markerad i referenssyfte
Visa hur långt som är kvar
Mätvärde, t.ex. vid diskanvändning
Datum, Tid, eller båda
Annotering av (primärt) östasiatisk text
Nya taggar
•
•
•
•
•
•
•
•
wbr
canvas
command
details
summary
datalist
keygen
output
Hint för vad radbrytning kan göras
Dynamisk rityta för javascript
Kommando som användaren kan anropa
Mera information om något, kan öppnas
Sammanfattning av innehållet i details
Lista av värden för <input type=”list”>
Gränssnitt för generering av nyckelpar
Någon slags utdata, t.ex. från beräkning
(Några) ändrade taggar
•
•
•
•
•
•
•
•
b
cite
hr
i
menu
s
small
strong
Stilistiskt annorlunda, utan extra vikt
Titeln på ett refererat verk
Tematiskt avbrott
Text i annan stil, eller typografiskt kursiv
Toolbar eller meny
Inte längre relevant text
Finstilt
Vikt snarare än betoning
Borttagna taggar
Presentionstaggar
• basefont
• big
• center
• font
• strike
• tt
• u
Tillgänglighetsproblem
• frame
• frameset
• noframes
Har bättre ersättare
• acronym
• applet
• isindex
• dir
Nya attribut för input-element
•
•
•
•
•
•
•
•
•
•
•
•
•
tel
search
url
email
datetime
date
month
week
time
datetime-local
number
range
color
• Fallback till text där det inte känns igen.
• Möjlighet att göra javascript-version
•
•
där stöd saknas.
Validering client-side
Default-styling görs i webbläsaren
Några intressanta attribut
meta: charset
<meta http-equiv="Content-Type“
content="text/html; charset=UTF-8">
input: autofocus
input:
placeholder
style: scoped
html: manifest
iframe: sandbox
<input type=”text” autofocus>
<input type=”text” placeholder=”http://”>
<style scoped> p { color: blue; } </style>
<html manifest=”clock.manifest”>
<iframe sandbox></iframe>
Och 20-30 attribut till...
Microdata-attribut
<div>
<h1>Hendershot's Coffee Bar</h1>
<p>1560 Oglethorpe Ave, Athens, GA</p>
</div>
Microdata-attribut
<div itemscope itemtype="http://data-vocabulary.org/Organization">
<h1 itemprop="name">Hendershot's Coffee Bar</h1>
<p itemprop="address" itemscope itemtype="http://datavocabulary.org/Address">
<span itemprop="street-address">1560 Oglethorpe Ave</span>,
<span itemprop="locality">Athens</span>,
<span itemprop="region">GA</span>.
</p>
</div>
Nya Javascript API:er
• Canvas
• Cross-document
•
•
•
•
•
Messaging
Geolocation
Inline Editing
Local storage
Selectors
Video & Audio
• Cross-Origin Resource
•
•
•
•
•
•
•
Sharing
Drag and Drop
History
Offline apps
Server events
WebGL
Web sockets
Web workers
Nya Javascript API:er
• Canvas
• Cross-document
•
•
•
•
•
Messaging
Geolocation
Inline Editing
Local storage
Selectors
Video & Audio
• Cross-Origin Resource
•
•
•
•
•
•
•
Sharing
Drag and Drop
History
Offline apps
Server events
WebGL
Web sockets
Web workers
Canvas
• <canvas id="c" width="150" height="150”></canvas>
• http://code.google.com/p/explorercanvas/
Canvas
• <canvas id="c" width="150" height="150">
<img src="clock.png" width="150" height="150">
</canvas>
• Göm <img> för Safari, som kan visa <canvas> men
inte stödjer fallback
Canvas
var canvas = document.getElementById('tutorial');
var ctx = canvas.getContext('2d');
ctx.fillStyle = "rgb(200,0,0)";
ctx.fillRect(10, 10, 55, 50);
ctx.fillStyle = "rgba(0, 0, 200, 0.5)";
ctx.fillRect(30, 30, 55, 50);
Cross-document Messaging #1
<iframe src="http://dev.jquery.com/~john/message/" id="iframe"></iframe>
<form id="form">
<input type="text" id="msg" value="Message to send"/>
<input type="submit"/>
</form>
<script>
window.onload = function(){
var win = document.getElementById("iframe").contentWindow;
document.getElementById("form").onsubmit = function(e){
win.postMessage( document.getElementById("msg").value );
e.preventDefault();
};
};
</script>
Cross-document Messaging #2
<b>This iframe is located on dev.jquery.com</b>
<div id="test">Send me a message!</div>
<script>
document.addEventListener("message", function(e){
document.getElementById("test").textContent =
e.domain + " said: " + e.data;
}, false);
</script>
Cross-document Messaging
• http://benalman.com/projects/jquery-postmessage-plugin/
Geolocation
if (navigator.geolocation) {
navigator.geolocation.getCurrentPosition(
function (position) {
alert(
position.coords.latitude,
position.coords.longitude
);
},
function (error){ ... }
)
}
Geolocation
if (navigator.geolocation) {
navigator.geolocation.watchPosition(
function (position) {
alert(
position.coords.latitude,
position.coords.longitude
);
},
function (error){ ... }
)
}
Geolocation
http://gears.google.com
Inline editing
http://accessgarage.wordpress.com/2009/05/08/howto-hack-your-app-to-make-contenteditable-work/
Local Storage
• sessionStorage – För en browsersession
• localStorage – Över flera sessioner, knutna till en
viss domän
sessionStorage
var field = document.getElementById("field");
if ( sessionStorage.autosave ) {
field.value = sessionStorage.autosave;
}
setInterval(function(){
sessionStorage.autosave = field.value;
}, 1000);
sessionStorage
http://code.google.com/p/sessionstorage/
Selectors API
<table id="score">
<tr>
<td>A</td>
<td>87%</td>
</tr><tr>
<td>B</td>
<td>78%</td>
</tr><tr>
<td>C</td>
<td>81%</td>
</tr>
</table>
var cells = document.querySelectorAll(
"#score > tr > td:nth-of-type(2)"
);
Selectors API
<table id="score">
<tr>
<td>A</td>
<td>87%</td>
</tr><tr>
<td>B</td>
<td>78%</td>
</tr><tr>
<td>C</td>
<td>81%</td>
</tr>
</table>
var cells = document.querySelector(
"#score > tr > td:nth-of-type(2)"
);
Selectors API
• http://sizzlejs.com/ (4 kb)
Audio API
<audio id="a" controls>
<source src="elvis.mp3" />
<source src="elvis.ogg" />
<!-- fallback -->
</audio>
Audio API
<input type="button" value="Play" id="playpause"
onclick="video.play()">
var audio = document.getElementById(”a”);
var playpause = document.getElementById('playpause');
audio.onpause = function(e) {
playpause.value = 'Play';
playpause.onclick = function(e) { video.play(); }
}
video.onplay = funtion(e) {
playpause.value = 'Pause';
playpause.onclick = function(e) { video.pause(); }
}
Audio API
Video API
<video width="320" height="240" controls>
<source src="pr6.mp4" type='video/mp4;codecs="avc1.42E01E,
mp4a.40.2"'>
<source src="pr6.webm" type='video/webm; codecs="vp8, vorbis"'>
<source src="pr6.ogv" type='video/ogg; codecs="theora, vorbis"'>
</video>
Video API
var idata = bc.getImageData(0,0,w,h);
var data = idata.data;
for(var i = 0; i < data.length; i+=4) {
var r = data[i];
var g = data[i+1];
var b = data[i+2];
var brightness = (3*r+4*g+b)>>>3;
data[i] = brightness;
data[i+1] = brightness;
data[i+2] = brightness;
}
idata.data = data;
c.putImageData(idata,0,0);
Video API
Hur gör man?
<!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="sv"
xml:lang="sv">
<head>
<title>Stockholms universitet: Startsida</title>
<meta http-equiv="content-type" content="text/html;
charset=ISO-8859-1" />
<link rel="stylesheet" type="text/css" href="style.css"/>
Hur gör man?
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"
lang="sv" xml:lang="sv">
<head>
<title>Stockholms universitet: Startsida</title>
<meta http-equiv="content-type"
content="text/html; charset=ISO-8859-1" />
<link rel="stylesheet" type="text/css"
href="style.css"/>
Hur gör man?
<!DOCTYPE html>
<html lang="sv">
<head>
<title>Stockholms universitet: Startsida</title>
<meta http-equiv="content-type"
content="text/html; charset=ISO-8859-1" />
<link rel="stylesheet" type="text/css"
href="style.css"/>
Hur gör man?
<!DOCTYPE html>
<html lang="sv">
<head>
<title>Stockholms universitet: Startsida</title>
<meta charset="ISO-8859-1">
<link rel="stylesheet" type="text/css"
href="style.css"/>
Hur gör man?
<!DOCTYPE html>
<html lang="sv">
<head>
<title>Stockholms universitet: Startsida</title>
<meta charset="ISO-8859-1">
<link rel="stylesheet" href="style.css"/>
Förhållandet till XHTML
• 99% validerar inte idag
• Många skickar XHTML som text/html
• Två vägar:
• Gör HTML striktare (XHTML 2)
• Gör specifikationen friare  vägen som valdes
• Men... finns också en XML-serialisering av HTML5,
kallad XHTML5.
Vad krävs för XHTML5?
•
•
•
•
Att man följer XML-specifikationen
Möjligt att vara både HTML och XHTML
Valfritt med DOCTYPE
SVG och MathML tillåtet i HTML
Vad krävs för XHTML5?
• Skickar som MIME-type: application/xml eller
•
•
•
•
•
•
•
application/xhtml+xml
<?xml version="1.0" encoding="UTF-8"?>
Ingen användning av document.write()
XML-namespace för alla HTML-taggar: xmlns
Syntax: <br/> <span class=”type”>
Inga ”--” inne i kommetarer
<![CDATA[...]]> för HTML-taggar som ej parsas
CSS blir case-sensitive
Frågor kring tillgänglighet
• Hur tolkar skärmläsare de nya taggarna?
• Tolkning av nästlade rubriknivåer
• Nya tillgänglighetsfunktioner
• WAI-ARIA, role-attributet
• Mer struktur för innehåll, inkl. <nav>
• Nya problem?
• Fallback för video, audio, canvas?
Tolkning av nya taggar
• Alla de vanligaste skärmläsarna är plugins
• Skärmläsare klarar det som webbläsare klarar
• http://www.accessibleculture.org/research/html5aria/
• JAWS 11, Window-Eyes 7.11, SAToGO 3.0.202, VoiceOver
• Internet Explorer 8 och Firefox 3.6
Nya tillgänglighetsfeatures
•
•
•
•
•
•
Semantiska element
Nya formulärfälttyper m. tangentbord
Audio & Video: Tangentbord + Captioning
Drag & Drop: Tangentbord
Text-alternativ till bilder (font-face...)
Alla har potiential, men ingen stöds ännu. Hönan
eller ägget?
• Varning: Hela gränssnitt i Canvas (t.ex. Bespin)
ARIA Landmark Roles
• Fungerar idag, validerar med HTML5
• Överlapp med HTML5-element, men stöds redan av
flera skärmläsare
• <nav role=”navigation”>
• Roller: application, banner, complementary,
contentinfo, form, main, navigation, search
Exempel: JAWS
ARIA
• Del av ARIA, som tävlar med HTML5 om att vara
först med tillgänglighetsfeatures, håll koll.
• “If the host language incorporates ARIA support and
there is a conflict between a host language feature
and an ARIA feature, assistive technologies should
assign preference to the ARIA feature.”
ARIA Spec.
Argument för HTML5
• Tekniska:
• HTML
• Javascript
• Interoperabilitet
HTML-delen
•
•
•
•
HTML5 beskriver parsning, inte bara spec
Fungerar rakt av med din befintliga kod
Semantik möjliggör nya features på din kod
Mindre kod att skriva, som man kommer ihåg, kan
någon rabbla en html4-doctype?
• Oro hos vissa: Dåligt verktygsstöd?
• Enda som behöver ändras är doctype...
Javascript
• Spec:en startade som ”Web applications 1.0”
• Tydligt mål att ge webbsidor samma möjligheter som desktopapplikationer
• Extra tydligt i mobilvärlden, där webbsajter har samma möjligheter
som native-appar.
• Lika bra att börja experimentera nu, så att man är på banan när ännu
flera features kommer
Javascript
• Prestanda:
• QuerySelector
• Canvas
• Web Workers
• Web sockets
• WebGL
• Interaktiv grafik:
• Video
• Audio
• Canvas
• WebGL
Vare sig ni vill eller inte...
• Webbläsartillverkare != Webbutvecklare
• Samtliga kommer byta till HTML5-parsers
• http://caniuse.com/
Sökmotorer
• Bra:
• Mer innehåll i text-form
• Värdering (article > footer)
• Segmentering (article, article, article)
• Dåligt:
• Oklart vad som stöds idag
• Multipla nästlade hX-taggar
Sökmotorer
Bakåtkompatibilitet
• En parser  HTML5
•
måste fungera för allt
gammalt innehåll
Problem:
• Internet Explorer < 9
• Fallback för HTML
• Javascript-funktioner
Internet Explorer < 9
•
•
•
•
Stödjer inte CSS-styling av HTML5-element
Får inte heller vara med i CSS-selektorer
Kan inte köra javascript på HTML5-element
Utskrift blir fel fast de andra är lösta
Internet Explorer < 9
• document.createElement(”nav”)
• Utskrift: Byt element mot div temporärt
• http://html5shim.googlecode.com/svn/trunk/html5.js
• Alternativ för avslagen JS:
• Styla andra element
• Använd * istället för elementen
• Använd special-CSS i noscript-tagg
Fallback för HTML-element
• Okända element beter sig som span
• article, aside, details, figcaption, figure,
footer, header, hgroup, menu ,nav, section {
display:block;
}
•
•
• http://html5doctor.com/html-5-reset-stylesheet/
Canvas, Video, Audio fallback
• elementets innehåll
Okända attribut på forumlärfält
• Faller tillbaka på type=”text”. Använd JS för stöd.
Javascriptfunktioner
• Detektera stöd (väldefinerat), och använd bibliotek
för att ersätta
• Använd inbyggd funktionalitet om det går...
• Modernizr bibliotek för att detektera
• Klasser på body-taggen som kan användas från CSS-filen
Verktyg
• HTML5 Validator: http://html5.validator.nu/
• HTML5 Outliner:
http://gsnedders.html5.org/outliner/
Källor
• http://diveintohtml5.org/
• http://github.com/Modernizr/Modernizr/wiki/HTML5•
•
•
•
•
Cross-browser-Polyfills
http://www.slideshare.net/benschwarz/building-abetter-web
http://www.slideshare.net/stevefaulkner/html-5accessibility
http://www.brucelawson.co.uk/2009/redesigning-withhtml-5-wai-aria/
http://www.slideshare.net/remy.sharp/html5-js-apis
http://dev.opera.com/articles/view/everything-youneed-to-know-about-html5-video-and-audio/