ebook img

HTML5 Programming Cookbook PDF

67 Pages·3.119 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview HTML5 Programming Cookbook

HTML5ProgrammingCookbook i HTML5 Programming Cookbook HTML5ProgrammingCookbook ii Contents 1 HTML5DragandDrop 1 1.1 Settinguptwodivs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.2 Maketheelementsdraggable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 1.3 Setupeventstohandledragfunctionality . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 1.4 Completingthedropandputtingitalltogether . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3 1.5 Conclusionandfurtherapplications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 2 HTML5FileUploadExample 6 2.1 ShowFile(s)information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 2.1.1 Asinglefile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 2.1.2 Multiplefiles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 2.1.3 PreviewingFiles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 2.2 UploadThefiles. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 2.2.1 TheHTML . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 2.2.2 TheJavaScript . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 2.2.3 ThePHPscript . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 2.3 Download . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 3 HTML5DropdownMenuWithCSS3 10 3.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 3.2 HTML . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 3.3 CSS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 3.4 Downloadthesourcecode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 4 HTML5AudioPlayer 15 4.1 Theminimalexample . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 4.2 Showthecontrols . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 4.3 TagAttributes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 4.3.1 Controls . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 4.3.2 Autoplay . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 4.3.3 Loop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 HTML5ProgrammingCookbook iii 4.3.4 Preload . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 4.4 ControltheaudiowithJavascript . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 4.4.1 BasicPlay/Pauseexample. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 4.4.2 TheHTMLMediaElement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 4.4.2.1 Properties . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 4.4.2.2 Methods . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 4.5 UseMediaEvents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 4.5.1 Example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 4.6 PlaylistExample . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 4.6.1 TheSpecifications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 4.6.2 Thecode... . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 4.7 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 5 HTML5LocalStorage 23 5.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 5.2 LocalStorage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 5.3 SessionStorage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 5.4 Keypoints . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 5.5 DownloadtheSourceCode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 6 HTML5GraphicsandAnimation 28 6.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 6.2 Canvaselementandcontext. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 6.3 DrawaGraph . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 6.4 DrawaLine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 6.5 DrawArc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 6.6 Drawsomemorestuff. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 6.7 IntroducingrequestAnimationFrame . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 6.8 Downloadthesourcecode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 7 HTML5OfflineWebApplication 35 7.1 TheManifest . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 7.2 ManifestSections . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 7.3 ApplicationCacheAPI . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 7.3.1 Events. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 7.3.2 Properties . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 7.3.3 Methods . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 7.4 Theonline/offlineevents. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 7.5 AWorkingExample . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 7.5.1 Projectstructure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 7.5.2 Theserver.phpfile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 7.5.3 ThemainHTMLfile . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40 7.5.4 TheJavaScript . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41 7.6 Download . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 HTML5ProgrammingCookbook iv 8 HTML5Geolocation 44 8.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44 8.2 SecurityAndAccuracy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 8.3 WeatherWidget . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 8.4 getCurrentPositionandwatchPosition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 8.5 Position . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 8.6 HandlingJSON . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 8.7 Download . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 8.8 Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 9 HTML5FormValidation 51 9.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 9.1.1 minandmax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 9.1.2 datalist . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54 9.1.3 placeholder . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 9.1.4 autofocus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 9.1.5 pattern . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55 9.1.6 date,datetime-local,month,time,week . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56 9.1.7 email . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57 9.1.8 url . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 9.1.9 color . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 HTML5ProgrammingCookbook v Copyright (c) Exelixis Media P.C., 2015 All rights reserved. Without limiting the rights under copyright reserved above, no part of this publication may be reproduced, stored or introduced into a retrieval system, or transmitted, in any form or by any means (electronic, mechanical, photocopying, recording or otherwise), without the prior written permission of the copyright owner. HTML5ProgrammingCookbook vi Preface HTML5 is a core technology markup language of the Internet used for structuring and presenting content for the World Wide Web. AsofOctober2014thisisthefinalandcompletefifthrevisionoftheHTMLstandardoftheWorldWideWebConsortium (W3C).Thepreviousversion,HTML4,wasstandardisedin1997. Itscoreaimshavebeentoimprovethelanguagewithsupportforthelatestmultimediawhilekeepingiteasilyreadablebyhumans andconsistentlyunderstoodbycomputersanddevices(webbrowsers, parsers, etc.). HTML5isintendedtosubsumenotonly HTML4,butalsoXHTML1andDOMLevel2HTML.(Source: http://en.wikipedia.org/wiki/HTML5) In this ebook, we provide a compilation of HTML5 based examples that will help you kick-start your own web projects. We coverawiderangeoftopics,fromgraphicsandanimation,togeolocationandofflinestorage. Withourstraightforwardtutorials, youwillbeabletogetyourownprojectsupandrunninginminimumtime. HTML5ProgrammingCookbook vii About the Author WCGs(WebCodeGeeks)isanindependentonlinecommunityfocusedoncreatingtheultimateWebdevelopersresourcecenter; targetedatthetechnicalarchitect,technicalteamlead(seniordeveloper),projectmanagerandjuniordevelopersalike. WCGs serve the Web designer, Web developer and Agile communities with daily news written by domain experts, articles, tutorials,reviews,announcements,codesnippetsandopensourceprojects. Youcanfindthemonlineathttp://www.webcodegeeks.com/ HTML5ProgrammingCookbook 1/59 Chapter 1 HTML5 Drag and Drop Usability,animportantpartofwebinterfaceeasesthewaywecommunicatewithweb.Manynewtechnologiesandfunctionalities areinventedtoeasethedevelopmenteffortaswellasimprovetheoverallwayinwhichusersinteractwithweb. HTML5 has given many things as of today to improve the browser functionalities on client side with minimum amount of scripting. Itprovidesagreatwaytoimplementdraganddropfunctionalityinmodernbrowsers. Wearegoingtoseehowitis implementedwithabasicexampleofdragginganddroppingaimagefromonedivtoanother. ToachievedraganddropfunctionalitywithtraditionalHTML4,developerswouldhavetousecomplexJavascriptcode. HTML 5providesaDragandDropAPIthatbringssupporttothebrowsermakingitmucheasiertocodeup. Noextrapluginsneededto beinstalled. Itissupportedbythefollowingmajorbrowsers: • InternetExplorer9+ • Firefox • Opera,Chrome • Safari Note: DraganddropdoesnotworkinSafari5.1.7andearlierversions. 1.1 Setting up two divs Wewillfirstcodetwocreatetwodivboxes. Onedivwillcontaintheimagetobedragged. Theotherdivwillbethedestination wheretheimageneedstobedragged. <!DOCTYPE html> <html> <head> <style> #div1, #div2 {float:left; width:280px; height:180px; margin:10px;padding:10px;border:1px solid # ←(cid:45) aaaaaa;} </style> </head> <body> <img src="drag.png" width="250" height="150" id="drag1"> HTML5ProgrammingCookbook 2/59 </body> </html> Outputforabovecodeistwodivboxeswithonedivboxcontainingourimage Figure1.1: Initialdivs 1.2 Make the elements draggable Now,weneedtofirstmaketheimagedraggable. Settheattribute"draggable =true" <img src="drag.png" draggable="true" width="250" height="150" id="drag1"> 1.3 Set up events to handle drag functionality SettheondragstarteventintheimgtagtocalldragInitiliaze()functionasfollows: <img src="drag.png" draggable="true" ondragstart="return dragInitialize(event)" width="250" ←(cid:45) height="150" id="drag1"> TheondragstarteventinimgtagdetectswhenthedragisinitializedandthenitcallsthedragInitiate()function.The dragInitiate()function,thencatchestheevent.ItsetstheeffectAllowedvalueto"move"andhasdataTransfer. setData()methodwhichsetsthedatatypeandthevalueofthedraggeddata. <script type="text/javascript">

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.