html5 workshop, part 2

of 100 /100
HTML5 APIs - Where No Man Has Gone Before!

Author: robert-nyman

Post on 29-Aug-2014

2.192 views

Category:

Technology


2 download

Embed Size (px)

DESCRIPTION

Workshop given at Jfokus 2012

TRANSCRIPT

  • HTML5 APIs -Where No Man Has Gone Before!
  • classList
  • var elm = document.getElementById("classlist-demo");elm.classList.add("boxy");elm.classList.add("pretty");elm.classList.remove("pretty");elm.classList.toggle("pretty");elm.classList.contains("pretty");elm.classList.toString();
  • Custom data attributes
  • An element with custom data attributes

  • var customAttributes = document.getElementById("custom-attributes");customAttributes.getAttribute("data-type");customAttributes.getAttribute("data-value");
  • customAttributes.dataset.type;
  • var dataset = [];for (var i in customAttributes.dataset) { dataset.push(i + ": " + customAttributes.dataset[i]);}
  • Video
  • // Methodsvideo.canPlayType();video.load();video.pause();video.play();
  • // Propertiesvideo.paused;video.muted;video.autobuffer;video.autoplay;video.buffered; (Unimplemented)video.bufferedBytes; (Unimplemented)video.bufferingRate; (Unimplemented)video.bufferingThrottled; (Unimplemented)video.controls;video.currentSrc;video.currentTime;video.defaultPlaybackRate;video.duration;video.ended;video.error;video.muted;video.networkState;video.paused;video.playbackRate;video.readyState;video.seeking;video.src;video.totalBytes;video.volume;
  • // Eventsvideo.abort;video.canplay;video.canplaythrough;video.canshowcurrentframe;video.dataunavailable;video.durationchange;video.emptied;video.empty;video.ended;video.error;video.loadedfirstframe;video.loadedmetadata;video.loadstart;video.pause;video.play;video.progress; (lengthComputable, loaded, total)video.ratechange;video.seeked;video.seeking;video.suspend;video.timeupdate;video.volumechange;
  • Canvas
  • I am canvas
  • var canvas = document.getElementById("my-canvas"), context = canvas.getContext("2d");context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);
  • context.save();context.fillStyle = "rgba(0, 0, 200, 0.5)";context.fillRect(50, 50, 100, 100);context.clearRect(40, 40, 20, 20);context.restore();
  • context.fillRect(350, 50, 100, 100);context.lineWidth = "10";context.lineJoin = "round";context.moveTo(50, 50);context.lineTo(200, 200);context.lineTo(100, 300);context.closePath();context.stroke();context.fill();context.beginPath();context.strokeStyle = "#00f";context.arc(200, 400, 75, 0, Math.PI*2, false);context.stroke();
  • context.fillStyle = "#fff";context.fillRect(0, 0, 200, 200);context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);context.fillRect(100, 100, 100, 100);
  • context.strokeStyle = "transparent";context.arc(100, 100, 75, 0, Math.PI*2, false);context.clip();context.stroke();context.fillStyle = "#fff";context.fillRect(0, 0, 200, 200);context.fillStyle = "#f00";context.fillRect(0, 0, 100, 100);context.fillRect(100, 100, 100, 100);
  • var canvas = document.getElementById("my-canvas"), context = canvas.getContext("2d"), img = document.createElement("img");img.addEventListener("load", function () { context.drawImage(img, 0, 0, 600, 200); // Get canvas content as a base64 image var base64Img = canvas.toDataURL("image/png");}, false);img.setAttribute("src", "view.jpg");
  • 
  • pdf.js
  • Web Storage
  • sessionStorage.setItem("Charming", "Anthony Weiner");console.log(sessionStorage.getItem("Charming"));
  • localStorage.setItem("Occupation", "Politician");
  • var anthonyWeiner = { "Interest" : "Photography", "Social" : "Twitter"};localStorage.setItem("anthonyWeiner", JSON.stringify(anthonyWeiner));console.log(typeof JSON.parse(localStorage.getItem("anthonyWeiner")));
  • Web SQL IndexedDB
  • IndexedDB
  • var indexedDB = window.indexedDB || window.webkitIndexedDB|| window.mozIndexedDB || window.msIndexedDB;var request = indexedDB.open("ABBADatabase");
  • var request = indexedDB.open("ABBADatabase", 2), customerData = [ {ssn: "444-44-4444", name: "Bill", age: 35, email: "[email protected]"}, {ssn: "555-55-5555", name: "Donna", age: 32, email: "[email protected]"} ];request.onerror = function(event) { // Handle errors.};request.onupgradeneeded = function (event) { var objectStore = db.createObjectStore("customers", { keyPath: "ssn"} ); objectStore.createIndex("name", "name", { unique: false }); objectStore.createIndex("email", "email", { unique: true } ); for (var i in customerData) { objectStore.add(customerData[i]); }};
  • Ofine Web Applications
  • if (window.addEventListener) { /* Works well in Firefox and Opera with the Work Offline option in the File menu. Pulling the ethernet cable doesnt seem to trigger it */ window.addEventListener("online", isOnline, false); window.addEventListener("offline", isOffline, false);}else { /* Works in IE with the Work Offline option in the File menu and pulling the ethernet cable */ document.body.ononline = isOnline; document.body.onoffline = isOffline;}
  • // Poll the navigator.onLine propertysetInterval(function () { console.log(navigator.onLine);}, 1000);
  • ...
  • CACHE MANIFEST# VERSION 10CACHE:offline.htmlbase.cssFALLBACK:online.css offline.cssNETWORK:/live-updates
  • Geolocation
  • if (navigator.geolocation) { navigator.geolocation.getCurrentPosition(function (position) { alert(position.coords.latitude + ", " + position.coords.longitude); });}
  • History API
  • window.history.pushState(state, title, url);
  • var url = "http://robertnyman.com",title = "My blog",state = { address : url};window.history.pushState(state, title, url);
  • Web Sockets
  • LiveConnect Forever Frame HTTP Long-Polling and XHR Streaming What came before WebSockets? AJAX HTTP PollingCross Frame Communication
  • var ws = new WebSocket("ws://robertnyman.com/wsmagic");// Send dataws.send("Some data");// Close the connectionws.close();
  • var ws = new WebSocket("ws://robertnyman.com/wsmagic");// When connection is openedws.onopen = function () { console.log("Connection opened!");};// When you receive a messagews.onmessage = function (evt) { console.log(evt.data);};// When you close the connectionws.onclose = function () { console.log("Connection closed");};// When an error occurredws.onerror = function () { console.log("An error occurred");};
  • web-socket-js Socket.IO
  • File API
  • var filesUpload = document.getElementById("files-upload");filesUpload.onchange = function () { // Access to data about all files var files = this.files, file; for (var i=0, l=files.length; i
  • for (var i=0, l=files.length, file, img; i
  • // For Firefox, Google Chrome and Safarivar xhr = new XMLHttpRequest();xhr.open("post", "upload/upload.php", true);xhr.onreadystatechange = function() { if (this.readyState === 4) { // File uploaded }};// Upload file: Firefox, Google Chrome and Safarixhr.setRequestHeader("Content-Type", "multipart/form-data");xhr.setRequestHeader("X-File-Name", file.fileName);xhr.setRequestHeader("X-File-Size", file.fileSize);xhr.setRequestHeader("X-File-Type", file.type);xhr.send(file);
  • Drag and Drop
  • ...I am forced to conclude thatthe HTML5 drag and dropmodule is not just a disaster, itsa fucking disaster. -Peter-Paul Koch
  • Drag and drop files here

  • var someImg = document.getElementById("some-image"), dropArea = document.getElementById("drop-area");someImg.ondragstart = function (evt) { var event = evt || window.event; event.dataTransfer.setData("Text", this.getAttribute("alt")); return false;};dropArea.ondragenter = function (evt) { return false; If the drop is to be}; accepted, then thisdropArea.ondragover = function (evt) { return false; event (dragover) has}; to be canceled.dropArea.ondrop = function (evt) { var text = event.dataTransfer.getData("Text"); event.cancelBubble = true; // For IE return false;};
  • someImg.ondragstart = function (evt) { var event = evt || window.event; event.dataTransfer.setDragImage(dragIcon, -10, -10); return false;};
  • Web Workers
  • var worker = new Worker("worker.js");
  • // Main page code var worker = new Worker("worker.js"); // postMessage worker.postMessage(5); // Receive message back from Worker worker.onmessage = function (evt) { document.getElementById("worker-results").innerHTML= evt.data; }; // Error handling worker.onerror = function (evt) { document.getElementById("worker-results").innerHTML= "An error occurred"; };
  • // Web Worker codeonmessage = function (evt) { for (var i=evt.data, il=1000001; i
  • Fullscreen
  • Fullscreen
  • mozRequestFullScreenWithKeys?
  • html:-moz-full-screen { background: red;}html:-webkit-full-screen { background: red;}
  • Battery
  • // Get battery level in percentagevar batteryLevel = battery.level * 100 + "%";// Get whether device is charging or notvar chargingStatus = battery.charging;// Time until the device is fully chargedvar batteryCharged = battery.chargingTime;// Time until the device is dischargedvar batteryDischarged = battery.dischargingTime;
  • battery.addEventLister("levelchange", function () { // Devices battery level changed}, false);battery.addEventListener("chargingchange", function () { // Device got plugged in to power, or unplugged}, false);battery.addEventListener("chargingtimechange", function () { // Devices charging time changed}, false);battery.addEventListener("dischargingtimechange", function () { // Devices discharging time changed}, false);
  • Vibration
  • (function () { document.querySelector("#vibrate-one-second").addEventListener("click", function () { navigator.mozVibrate(1000); }, false); document.querySelector("#vibrate-twice").addEventListener("click", function () { navigator.mozVibrate([200, 100, 200, 100]); }, false); document.querySelector("#vibrate-long-time").addEventListener("click", function () { navigator.mozVibrate(5000); }, false); document.querySelector("#vibrate-off").addEventListener("click", function () { navigator.mozVibrate(0); }, false);})();
  • WebGL
  • squareVertexPositionBuffer = gl.createBuffer();gl.bindBuffer(gl.ARRAY_BUFFER, squareVertexPositionBuffer);vertices = [ 1.0, 1.0, 0.0, -1.0, 1.0, 0.0, 1.0, -1.0, 0.0, -1.0, -1.0, 0.0];gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(vertices), gl.STATIC_DRAW);squareVertexPositionBuffer.itemSize = 3;squareVertexPositionBuffer.numItems = 4;}
  • var teapotPositions = new Float32Array([ 17.83489990234375, 0, 30.573999404907227,16.452699661254883, -7.000179767608643, 30.573999404907227, 16.223100662231445,-6.902520179748535, 31.51460075378418, 17.586000442504883, 0, 31.51460075378418,16.48940086364746, -7.015810012817383, 31.828100204467773, 17.87470054626465, 0,31.828100204467773, 17.031099319458008, -7.246280193328857, 31.51460075378418,18.46190071105957, 0, 31.51460075378418, 17.62779998779297, -7.500199794769287,30.573999404907227, 19.108800888061523, 0, 30.573999404907227, 12.662699699401855,-12.662699699401855, 30.573999404907227, 12.486100196838379, -12.486100196838379,31.51460075378418, 12.690999984741211, -12.690999984741211, 31.828100204467773,13.10789966583252, -13.10789966583252, 31.51460075378418, 13.56719970703125,-13.56719970703125, 30.573999404907227, 7.000179767608643, -16.452699661254883,30.573999404907227, 6.902520179748535, -16.223100662231445, 31.51460075378418,7.015810012817383, -16.48940086364746, 31.828100204467773, 7.246280193328857,-17.031099319458008, 31.51460075378418, 7.500199794769287, -17.62779998779297,30.573999404907227, 0, -17.83489990234375, 30.573999404907227, 0, -17.586000442504883,31.51460075378418, 0, -17.87470054626465, 31.828100204467773, 0, -18.46190071105957,31.51460075378418, 0, -19.108800888061523, 30.573999404907227, 0, -17.83489990234375,30.573999404907227, -7.483870029449463, -16.452699661254883, 30.573999404907227,-7.106579780578613, -16.223100662231445, 31.51460075378418, 0, -17.586000442504883,31.51460075378418, -7.07627010345459, -16.48940086364746, 31.828100204467773, 0,-17.87470054626465, 31.828100204467773, -7.25383996963501, -17.031099319458008,31.51460075378418, 0, -18.46190071105957, 31.51460075378418, -7.500199794769287,-17.62779998779297, 30.573999404907227, 0, -19.108800888061523, 30.573999404907227,-13.092700004577637, -12.662699699401855, 30.573999404907227, -12.667499542236328,-12.486100196838379, 31.51460075378418, -12.744799613952637, -12.690999984741211,31.828100204467773, -13.11460018157959, -13.10789966583252, 31.51460075378418,-13.56719970703125, -13.56719970703125, 30.573999404907227, -16.61389923095703,-7.000179767608643, 30.573999404907227, -16.291099548339844, -6.902520179748535,31.51460075378418, -16.50950050354004, -7.015810012817383, 31.828100204467773,-17.033599853515625, -7.246280193328857, 31.51460075378418, -17.62779998779297,-7.500199794769287, 30.573999404907227, -17.83489990234375, 0, 30.573999404907227,-17.586000442504883, 0, 31.51460075378418, -17.87470054626465, 0, 31.828100204467773,-18.46190071105957, 0, 31.51460075378418, -19.108800888061523, 0, 30.573999404907227,-17.83489990234375, 0, 30.573999404907227, -16.452699661254883, 7.000179767608643,
  • Try new things
  • Robert Nymanrobertnyman.com/speaking/ [email protected]/html5/ Twitter: @robertnymanrobertnyman.com/css3/