Rob Crowther
Total Page:16
File Type:pdf, Size:1020Kb
A user-friendly reference guide HTML5 & CSS3 Rob Crowther MANNING www.allitebooks.com Hello! HTML5 & CSS3 www.allitebooks.com www.allitebooks.com Hello! HTML5 & CSS3 A user-friendly reference guide Rob Crowther MANNING SHELTER ISLAND www.allitebooks.com For online information and ordering of this and other Manning books, please visit www.manning.com. The publisher offers discounts on this book when ordered in quantity. For more information, please contact: Special Sales Department Manning Publications Co. 20 Baldwin Road PO Box 261 Shelter Island, NY 11964 Email: [email protected] ©2013 by Manning Publications Co. All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form or by means electronic, mechanical, photocopying, or otherwise, without prior written permission of the publisher. Many of the designations used by manufacturers and sellers to distinguish their products are claimed as trademarks. Where those designations appear in the book, and Manning Publications was aware of a trademark claim, the designations have been printed in initial caps or all caps. User Friendly artwork, characters, and strips used by permission from UserFriendly.Org. All Rights Reserved. Recognizing the importance of preserving what has been written, it is Manning’s policy to have the books we publish printed on acid-free paper, and we exert our best efforts to that end. Recognizing also our responsibility to conserve the resources of our planet, Manning books are printed on paper that is at least 15 percent recycled and processed without elemental chlorine. Manning Publications Co. Development editor: Cynthia Kane 20 Baldwin Road Copyeditor: Tiffany Taylor PO Box 261 Technical proofreader: Adam London Shelter Island, NY 11964 Typesetter: Marija Tudor Cover designer: Marija Tudor ISBN: 9781935182894 Printed in the United States of America 1 2 3 4 5 6 7 8 9 10 – MAL – 17 16 15 14 13 12 www.allitebooks.com brief contents PART 1 LEARNING HTML5 1 1 Introducing HTML5 markup 3 2 HTML5 forms 38 3 Dynamic graphics 73 4 Audio and video 119 5 Browser-based APIs 153 6 Network and location APIs 191 PART 2 LEARNING CSS3 231 7 New CSS language features 233 8 Layout with CSS3 271 9 Motion and color 313 10 Borders and backgrounds with CSS3 351 11 Text and fonts 392 v www.allitebooks.com www.allitebooks.com contents preface xv acknowledgments xvii about this book xix PART 1 LEARNING HTML5 1 1 Introducing HTML5 markup 3 Why do we need new elements? 4 New elements for page structure 7 Sectioning content 7 ❍ Headings, headers, and the outlining algorithm 9 ❍ Common page elements 15 The HTML DOCTYPE 17 New elements for content 18 Time 18 ❍ Images and diagrams with <figure> and <figcaption> 21 ❍ Emphasizing words and phrases 22 HTML5’s new global attributes 23 Accessibility with ARIA 24 ❍ Extending HTML with custom attributes 26 ❍ Expressing more than just document semantics with microdata 28 The HTML5 content model 29 Browser support 32 Supporting Internet Explorer 35 ❍ Enabling HTML5 support in Internet Explorer with html5.js 36 Summary 36 vii www.allitebooks.com viii contents 2 HTML5 forms 38 The limitations of HTML4 forms 39 Numbers, ranges, dates, and times 42 Validation 46 The required attribute 47 ❍ The min, max, and pattern attributes 47 ❍ Taking advantage of validation with CSS 49 ❍ Turning off validation 50 Email and URLs 51 Email addresses 51 ❍ Web addresses 53 Elements for user feedback 53 The <output> element 53 ❍ The <progress> element 55 The <meter> element 56 Less-common form controls 57 Telephone numbers 57 ❍ Color pickers 58 <keygen> 59 New attributes for the <input> element 59 Placeholder text 59 ❍ Form autofocus 61 ❍ Protecting private information with the autocomplete attribute 61 Extending forms with JavaScript 62 Customizing the validation messages 62 ❍ Triggering validation with JavaScript 64 ❍ Responding to any changes in value 64 ❍ Creating combo boxes with <datalist> 65 ❍ Easy ways to work with form values in JavaScript 67 Browser support and detecting HTML5 features 68 Browser inconsistencies 69 ❍ Detecting supported features 69 ❍ The html5-now library 71 Summary 72 3 Dynamic graphics 73 Getting started with <canvas>: shapes, images, and text 74 Drawing shapes 76 ❍ Placing images 82 ❍ Drawing text 84 Advanced <canvas>: gradients, shadows, and animation 87 Creating gradients 88 ❍ Drawing drop shadows 91 Transformations 92 ❍ Animation 94 www.allitebooks.com contents ix Getting started with SVG 96 Applying styles to SVG 98 ❍ Drawing common shapes 99 Images, text, and embedded content 101 ❍ Transforms, gradients, patterns, and declarative animation 105 SVG vs. <canvas> 112 Browser support 114 Supporting <canvas> in older versions of IE with explorercanvas 114 ❍ SVG in XML vs. SVG in HTML 115 Embedding SVG as an image 115 ❍ Referencing an SVG image from CSS 116 ❍ Embedding SVG as an object 116 SVG support in older browsers with SVG Web and Raphaël 116 Summary 118 4 Audio and video 119 Audio and video on the modern web 119 The <audio> element 123 Common attributes: controls, autoplay, loop, and preload 124 Codecs and license issues 129 ❍ Using multiple sources 133 The <video> element 134 <video> element attributes 135 ❍ Containers, codecs, and license issues 138 ❍ Easy encoding with Miro Video Converter 139 ❍ Advanced encoding with FFmpeg 140 Using multiple sources 142 Controlling audio and video with JavaScript 144 Integrating media with other content 146 Browser support 150 Web server configuration for audio and video 151 Supporting legacy browsers with Flash video 152 Summary 152 5 Browser-based APIs 153 Rich-text editing with the contenteditable attribute 154 Basic text editing 155 ❍ The spellcheck attribute 157 Applying formatting to the editable text 160 Natural user interaction with drag-and-drop 164 Basic drag-and-drop 167 ❍ Drag-and-drop in all browsers 169 www.allitebooks.com x contents Managing the Back button with the history API 173 Updating page state 175 ❍ Using location.hash 176 Example: Implementing an undo feature 177 Getting semantic with the microdata API 179 Using a single microdata format 180 ❍ Using multiple microdata formats 183 Lag-free interfaces with web workers 185 Browser support 189 Summary 189 6 Network and location APIs 191 Finding yourself with the Geolocation API 192 Finding your location 193 ❍ Finding your location more accurately 194 ❍ Finding your location continuously 195 Practical uses for geolocation 196 Communication in HTML5 200 Enabling more secure integration with cross-document messaging 201 ❍ Real-time communication with the WebSocket API 205 Offline web applications 208 Setting up a development environment 209 The application cache 211 ❍ Managing network connectivity in offline apps 215 Storing data for offline use 222 Local storage 223 ❍ Session storage 227 ❍ Putting it all together 228 Browser support 229 Summary 229 PART 2 LEARNING CSS3 231 7 New CSS language features 233 Choosing elements through their relationships 234 Selecting sets of elements with combinators 235 Selecting among a set of elements with pseudo-classes 240 contents xi Choosing elements by their attributes 251 Choosing what isn’t 255 ❍ Pseudo-elements 257 Choosing elements based on user interaction 261 Styling form elements based on state 262 ❍ Styling the page based on the target of the URL 265 Browser support 267 Using jQuery to support older browsers 269 Summary 270 8 Layout with CSS3 271 Underused CSS2 layout features 272 Placing elements on a line with inline-block 272 ❍ Grouping element dimensions with display: table 275 CSS3 improvements to CSS2 approaches 279 Mixing different length units with calc 279 ❍ Controlling the box model 284 Using media queries for flexible layout 285 Resolution detection 287 ❍ Changing layout based on orientation and aspect ratio 291 ❍ Additional device-detection features 292 The future of CSS layout 293 Using flexible boxes for nested layout 294 ❍ Using the CSS3 Grid Alignment module 298 ❍ Controlling content flow with CSS3 Regions 303 ❍ Making complex shapes with CSS3 Exclusions and Shapes 305 Browser support 308 inline-block in IE6 and IE7 309 ❍ calc in Chrome and Firefox 310 ❍ box-sizing in Firefox and Safari 5 310 Flexboxes in Chrome, Firefox, IE, and Safari 310 Media queries and old browsers 311 ❍ Regions and exclusions 311 Summary 311 9 Motion and color 313 Colors and opacity 314 Opacity 314 ❍ RGBA 318 ❍ HSL and HSLA 320 xii contents CSS transforms 323 2D transforms 324 ❍ 3D transforms 328 CSS transitions 330 Transition timing functions 334 ❍ Transition property 337 ❍ Transition delay 338 ❍ Triggering transitions with JavaScript 339 CSS Animation 343 Browser support 346 Opacity in IE8 and earlier 346 ❍ Transforms, transitions, and animations in current browsers 346 ❍ Using modernizr.js and jQuery for animation in older browsers 349 Summary 350 10 Borders and backgrounds with CSS3 351 Drop shadows with CSS3 352 Box shadows 352 ❍ Text shadows 356 Easy rounded corners 358 New features for background images 361 Background size 361 ❍ Multiple backgrounds 365 Background origin and clipping 369 Selective background scaling with border images 371 Basic border-image 372 ❍ Stretching and repeating border-image sections 374 ❍ Using border-image to create common effects 377 Creating gradients with CSS 378 Browser support 384 Cross-browser drop shadows 385 ❍ Cross-browser CSS3 gradients 386 ❍ Cross-browser backgrounds and border-image 387 ❍ Supporting old versions of Internet Explorer 388 ❍ CSS3 PIE for easy IE support 390 Summary