25
HTML5 and Designing a Rich Internet Experience Garth Colasurdo HSLIC Web and Applications Group [email protected]

HTML5 and Designing a Rich Internet Experience

  • Upload
    morley

  • View
    50

  • Download
    3

Embed Size (px)

DESCRIPTION

HTML5 and Designing a Rich Internet Experience. Garth Colasurdo HSLIC Web and Applications Group [email protected]. In This Presentation. HTML5 ≈ HTML 5 + CSS 3 + JavaScript Rich Internet Applications (RIA) HTML5 x 5 Caution and Progress Example and Reference Sites. - PowerPoint PPT Presentation

Citation preview

Page 1: HTML5 and Designing a Rich Internet Experience

HTML5 and Designing a Rich Internet Experience

Garth ColasurdoHSLIC Web and Applications Group

[email protected]

Page 2: HTML5 and Designing a Rich Internet Experience

In This Presentation

• HTML5 ≈ HTML 5 + CSS 3 + JavaScript• Rich Internet Applications (RIA)• HTML5 x 5• Caution and Progress• Example and Reference Sites

Page 3: HTML5 and Designing a Rich Internet Experience
Page 4: HTML5 and Designing a Rich Internet Experience

HTML5 ≈ HTML 5 + CSS 3 + JavaScript

• HTML5 is a suite of tools for:– Markup (HTML 5)– Presentation (CSS 3)– Interaction (DOM, Ajax, APIs)

• Brought on by the evolving use of the web

http://slides.html5rocks.com/

Page 5: HTML5 and Designing a Rich Internet Experience

A Rough History of Web Standards91-92 93-94 95-96 97-98 99-00 01-02 03-04 05-06 07-08 09-10 11-12 13-14HTML 1 HTML 2 HTML 4 XHTML

1HTML 5

CSS 1 CSS 2 T-less D Web 2.0 CSS3

JS ECMA, DOM

DOM 2 Ajax DOM, APIs

2004 WHATWG started

2008 W3C Working Draft

2012 (2010) W3C Candidate Rec

2022 W3C Rec

1996 – CSS 1 W3C Rec

1998 – CSS 2 W3C Rec

1999 – CSS 3 Proposed

2005 – CSS 2.1 W3C Candidate Rec

2001 – CSS 3 W3C Working Draft

HTML 5 CSS

Page 6: HTML5 and Designing a Rich Internet Experience

Rich Internet Applications (RIA)

• Space between the internet and the desktop• Apps that look good and behave well• Adobe Air/Flash, Java, Silverlight, Gears• Availability

– Anywhere a web browser is available– As a desktop widget or application– Part of a mobile application store

Page 7: HTML5 and Designing a Rich Internet Experience

RIA Examples

Page 8: HTML5 and Designing a Rich Internet Experience

5 HTML Enhancements

• HTML• Forms• CSS• Offline applications• Local storage

Page 9: HTML5 and Designing a Rich Internet Experience

HTML Extended

• Document Flow: div, section, article, nav, aside, header, footer

• Audio, Video and Embed• Canvas: paths, gradients, image manipulation,

events• Microdata for semantics and enhanced search

engine results (Google Rich Snippets)

Page 10: HTML5 and Designing a Rich Internet Experience

HTML

Header

Navigation

Aside

Footer

Section

ArticleFooter

ArticleFooter

ArticleFooter

Figure

Image, Video, Quote, Table, etc…

Legend

Page 11: HTML5 and Designing a Rich Internet Experience

Canvas<canvas id=“canvas” width=“150” height=“150”></canvas>

function draw() {var canvas = document.getElementById(“canvas”);if (canvas.getContext) {

var ctx = canvas.getContext(“2d”);ctx.fillStyle = “rgb(200,0,0)”;ctx.fillRect (10,10,55,50);

ctx.fillStyle = “rgb(0,0,200)”;ctx.fillRect (30,30,55,50);

}}

Page 12: HTML5 and Designing a Rich Internet Experience

Form Enhancements

• Placeholder text• Specific text input: email, URL, number, search• Slider• Date picker• User Agent validation

Page 13: HTML5 and Designing a Rich Internet Experience

CSS Effects• Rounded corners• Gradients• Box and text shadows• Fonts• Transparencies• Multiple background images and border images• Multiple columns and grid layout• Box sizing• Stroke and outlines• Animation, movement and rotation• Improved selectors

Page 14: HTML5 and Designing a Rich Internet Experience

CSS Effect Example.amazing {

border: 1px solid blue;

color: red;

background-color: gold;

-webkit-border-radius: 40px;

-moz-border-radius: 40px;

border-radius: 40px;

-webkit-box-shadow: 8px 8px 6px #474747;

-moz-box-shadow: 8px 8px 6px #474747;

box-shadow: 8px 8px 6px #474747;

text-shadow: 8px 8px 2px #595959;

filter: dropshadow(color=#595959, offx=8, offy=8);

}

Amazing CSS Amazing CSS EffectsEffects

Amazing CSS Amazing CSS EffectsEffects

http://css3generator.com/

Page 15: HTML5 and Designing a Rich Internet Experience

CSS Timelines

http://mattbango.com/notebook/web-development/pure-css-timeline/

Page 16: HTML5 and Designing a Rich Internet Experience

Programmer Tools

• Offline Applications• Storage• Communication

– Web Workers– Web Sockets

• Desktop experience– Drag and Drop– Notifications

• Geolocation

Page 17: HTML5 and Designing a Rich Internet Experience

Offline Applications<html mainfest=“http://m.health.unm.edu/someapp.manifest”>

</html>

someapp.manifestCACHE MANIFEST#v1.01

#Explicitly cached filesCACHE:index.htmlStylesheet.cssImages/logo.png

NETWORK:Search.cfmLogin.cfm/dynamicpages

FALLBACK:/dynamicpage.cfm /static.html

http://www.whatwg.org/specs/web-apps/current-work/multipage/offline.html

Page 18: HTML5 and Designing a Rich Internet Experience

Local Storage

• Beyond cookies- local storage– Manipulated by JavaScript– Persistent– 5MB storage per “origin”– Secure (no communication out of the browser)

• Session storage– Lasts as long as the browser is open– Each page and tab is a new session

• Browser based SQLite or IndexedDB

Page 19: HTML5 and Designing a Rich Internet Experience

Local Storage

• Web storagewindow.localStorage[‘value’] = ‘Save this!’;

• Session storagesessionStorage.useLater(‘fullname’, ‘Garth Colasurdo’);alert(“Hello ” + sessionStorage.fullname);

• Database storagevar database = openDatabase(“Database Name”, “Database Version”);database.executeSql(“SELECT * FROM test”, function(result1) { …});

http://dev.w3.org/html5/webstorage/

Page 20: HTML5 and Designing a Rich Internet Experience

User Agent Storage

Page 21: HTML5 and Designing a Rich Internet Experience

Cautions

• Browser implementation is fragmented• Standards are in development

– HTML Candidate Recommendation is scheduled for 2012

– CSS3 is in multiple drafts and proposals– ECMA-262 (edition 3) (or JavaScript 1.5)

• New markup and architecture design

Page 22: HTML5 and Designing a Rich Internet Experience

Progress• Multiple support levels

– HTML editors– CSS editors and frameworks– JavaScript libraries and frameworks

• Astounding user agent development– JavaScript engines– Rendering engines– Device awareness– Widget adoption– Robust vendor competition and cooperation

• Continue with progressive enhancement/graceful failure methods

Page 23: HTML5 and Designing a Rich Internet Experience

Advocacy Sites

• Total clearing house of HTML5 (start with the presentation)http://html5rocks.com

• HTML5 Watch is a list of interesting RIA advanceshttp://html5watch.tumblr.com

• CSS3 Bloghttp://www.css3.info

Page 24: HTML5 and Designing a Rich Internet Experience

Demos and Experiments• Chrome Experiments

http://www.chromeexperiments.com• Apple HTML5 Showcase

http://www.apple.com/html5/

• Canvas Demoshttp://www.canvasdemos.com

• RIA Demos with browser support listedhttp://html5demos.com

• Our Solar Systemhttp://neography.com/experiment/circles/solarsystem/

• Pure CSS3 Animated AT-AT Walker from Star Wars http://blog.optimum7.com/anthony/website-design/pure-css3-animated-at-at-walker-from-star-wars-2.html

Page 25: HTML5 and Designing a Rich Internet Experience

Developer Reference Sites• W3C

http://dev.w3.org/html5/html-author/http://w3.org/TR/css3-roadmap/

• W3Schools HTML 5 Referencehttp://www.w3schools.com/html5/

• Dive Into HTML 5 (prerelease site for an O’Reilly book)http://diveintohtml5.org

• WebKit (Safari and Chromium)http://developer.apple.com/safari/library/navigation/http://www.chromium/home/

• Mozillahttp://developer.mozilla.org/en/html/html5/

• IE 8 & 9http://msdn.microsoft.com/en-us/library/aa737439.aspxhttp://ie.microsoft.com/testdrive/