• Tidak ada hasil yang ditemukan

HTML & CSS The Complete Reference, 5th Edition

N/A
N/A
Protected

Academic year: 2019

Membagikan "HTML & CSS The Complete Reference, 5th Edition"

Copied!
857
0
0

Teks penuh

(1)
(2)
(3)

industry฀veteran.฀After฀an฀early฀stint฀at฀CERFnet฀in฀the฀฀ early฀‘90s,฀he฀founded฀Powell฀Internet฀Consulting฀(later฀ renamed฀PINT)฀in฀1994,฀a฀Web฀design฀and฀consulting฀services฀ firm.฀Today,฀PINT฀(pint.com)฀provides฀Web฀development,฀ design,฀and฀consulting฀services฀to฀large฀and฀small฀corporations฀ all฀over฀the฀United฀States฀in฀a฀variety฀of฀industries.

Beyond฀his฀involvement฀at฀PINT,฀Thomas฀is฀heavily฀ involved฀in฀the฀academic฀community.฀He฀developed฀the฀ University฀of฀California,฀San฀Diego฀Extension฀Web฀Publishing฀ program฀in฀the฀late฀1990s฀and฀continues฀to฀teach฀classes฀there฀ in฀Web฀development฀and฀design.฀He฀is฀also฀an฀instructor฀for฀ the฀UCSD฀Computer฀Science฀Department,฀where฀he฀teaches฀ classes฀in฀Web฀development฀and฀the฀theory฀of฀programming฀ languages.

Mr.฀Powell฀is฀well฀published,฀and฀his฀work฀has฀appeared฀ in฀numerous฀trade฀publications.฀He฀continues฀to฀publish฀ regularly฀in฀Network฀World.฀He฀also฀has฀published฀numerous฀ books฀on฀Web฀technology฀and฀design,฀including฀Ajax:฀The฀ Complete฀Reference,JavaScript:฀The฀Complete฀Reference,฀and฀ many฀others.฀His฀books฀have฀been฀translated฀into฀over฀฀ 12฀languages฀and฀are฀used฀around฀the฀world฀both฀in฀industry฀ and฀college฀settings.

About the Technical Editor

James฀H.฀(Jim)฀Pence฀is฀a฀full-time฀writer,฀editor,฀speaker,฀ singer,฀and฀performance฀chalk฀artist.฀Jim฀broke฀into฀book฀ publishing฀in฀2001฀with฀How฀to฀Do฀Everything฀with฀HTML,฀฀ a฀how-to฀book฀on฀Web฀authoring,฀written฀“by฀a฀nontechie฀for฀ nontechies,”฀and฀published฀by฀McGraw-Hill฀Professional.฀He฀ followed฀this฀book฀the฀same฀year฀with฀another฀book฀for฀ McGraw-Hill:฀Cascading฀Style฀Sheets:฀A฀Beginner’s฀Guide.฀ McGraw-Hill฀published฀a฀second฀edition฀of฀Jim’s฀HTML฀ book,฀re-titled฀How฀to฀Do฀Everything฀with฀HTML฀&฀XHTML,฀฀ in฀2003.

(4)

The Complete Reference,

Fifth Edition

Thomas฀A.฀Powell

(5)

ISBN: 978-0-07-174170-5

MHID: 0-07-174170-4

The material in this eBook also appears in the print version of this title: ISBN: 978-0-07-149629-2, MHID: 0-07-149629-7.

All trademarks are trademarks of their respective owners. Rather than put a trademark symbol after every occurrence of a trademarked name, we use names in an editorial fashion only, and to the benefit of the trademark owner, with no intention of infringement of the trademark. Where such designations appear in this book, they have been printed with initial caps.

McGraw-Hill eBooks are available at special quantity discounts to use as premiums and sales promotions, or for use in corporate training programs. To contact a representative please e-mail us at [email protected].

Information has been obtained by McGraw-Hill from sources believed to be reliable. However, because of the possibility of human or mechanical error by our sources, McGraw-Hill, or others, McGraw-Hill does not guarantee the accuracy, adequacy, or completeness of any information and is not responsible for any errors or omissions or the results obtained from the use of such information.

TERMS OF USE

This is a copyrighted work and The McGraw-Hill Companies, Inc. (“McGraw-Hill”) and its licensors reserve all rights in and to the work. Use of this work is subject to these terms. Except as permitted under the Copyright Act of 1976 and the right to store and retrieve one copy of the work, you may not decompile, disassemble, reverse engineer, reproduce, modify, create derivative works based upon, transmit, distribute, disseminate, sell, publish or sublicense the work or any part of it without McGraw-Hill’s prior consent. You may use the work for your own noncommercial and personal use; any other use of the work is strictly prohibited. Your right to use the work may be terminated if you fail to comply with these terms.

(6)

Part I

Core Markup

1฀ Traditional฀HTML฀and฀XHTML฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 3 2฀ Introducing฀HTML5฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 55 3฀ HTML฀and฀XHTML฀Element฀Reference฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 133

Part II

Core Style

4฀ Introduction฀to฀CSS฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 429 5฀ CSS฀Syntax฀and฀Property฀Reference฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 521 6฀ CSS3฀Proprietary฀and฀Emerging฀Features฀Reference฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 613

Part III

Appendixes

A฀ Character฀Entities฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 727 B฀ Fonts฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 751 C฀ Colors฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 765 D฀ URLs฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 783 E฀ Reading฀a฀Document฀Type฀Definition฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 801

฀ Index฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 809

(7)
(8)

Acknowledgments฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ xxi Introduction฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀. ฀ xxiii

Part I

Core Markup

1฀ Traditional฀HTML฀and฀XHTML฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 3

First฀Look฀at฀HTML฀and฀XHTML฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 3 Hello฀HTML฀and฀XHTML฀World฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 6 Viewing฀Markup฀Locally฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 8 Viewing฀Markup฀with฀a฀Web฀Server฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 10 HTML฀and฀XHTML:฀Version฀History฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 14 HTML฀and฀XHTML฀DTDs:฀The฀Specifications฀Up฀Close฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 16 Document฀Type฀Statements฀and฀Language฀Versions฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 18 (X)HTML฀Document฀Structure฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 20 The฀Document฀Head฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 23 The฀Document฀Body฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 28 Browsers฀and฀(X)HTML฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 31 Validation฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 37 The฀Doctype฀Switch฀and฀Browser฀Rendering฀Modes฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 39 The฀Rules฀of฀(X)HTML฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 41 HTML฀Is฀Not฀Case฀Sensitive,฀XHTML฀Is฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 41 Attribute฀Values฀May฀Be฀Case฀Sensitive฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 42 (X)HTML฀Is฀Sensitive฀to฀a฀Single฀Whitespace฀Character฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 42 (X)HTML฀Follows฀a฀Content฀Model฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 43 Elements฀Should฀Have฀Close฀Tags฀Unless฀Empty฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 43 Unused฀Elements฀May฀Minimize฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 43 Elements฀Should฀Nest฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 43 Attributes฀Should฀Be฀Quoted฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 44 Entities฀Should฀Be฀Used฀for฀Special฀Characters฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 44 Browsers฀Ignore฀Unknown฀Attributes฀and฀Elements฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 44 Major฀Themes฀of฀(X)HTML฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 45 Logical฀and฀Physical฀Markup฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 45 Standards฀vs.฀Practice฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 46 Myths฀and฀Misconceptions฀About฀HTML฀and฀XHTML฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 47 The฀Future฀of฀Markup—Two฀Paths?฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 49 XHTML:฀Web฀Page฀Markup฀XML฀Style฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 49 HTML5:฀Back฀to฀the฀Future฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 52 Summary฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 53

2฀ Introducing฀HTML5฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 55

Hello฀HTML5฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 55 Loose฀Syntax฀Returns฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 58 XHTML5฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 60

(9)
(10)

3฀ HTML฀and฀XHTML฀Element฀Reference฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 133

(11)

<address>฀ (Address)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 168 <applet>฀ (Java฀Applet)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 169 <area>฀ (Image฀Map฀Area)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 171 <article>฀ (Article)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 175 <aside>฀ (Aside)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 176 <audio>฀ (Audio)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 177 <b>฀ (Bold)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 179 <base>฀ (Base฀URL)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 181 <basefont>฀ (Base฀Font)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 182 <bdo>฀ (Bidirectional฀Override)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 183 <bgsound>฀ (Background฀Sound)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 185 <big>฀ (Big฀Font)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 186 <blink>฀ (Blinking฀Text)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 187 <blockquote>฀ (Block฀Quote)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 188 <body>฀ (Document฀Body)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 190 <br>฀ (Line฀Break)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 193 <button>฀ (Form฀Button)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 195 <canvas>฀ (Canvas฀for฀Drawing)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 198 <caption>฀ (Table฀Caption)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 208 <center>฀ (Center฀Alignment)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 210 <cite>฀ (Citation)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 211 <code>฀ (Code฀Listing)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 213 <col>฀ (Table฀Column)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 214 <colgroup>฀ (Table฀Column฀Group)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 216 <command>฀ (Command)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 219 <comment>฀ (Comment฀Information)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 220 <datalist>฀ (List฀of฀Prefill฀Data)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 220 <dd>฀ (Definition฀Description฀in฀a฀Definition฀List฀฀

or฀Content฀in฀Details฀or฀Figure)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 222 <del>฀ (Deleted฀Text)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 224 <details>฀ (Additional฀Details)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 227 <dfn>฀ (Definition)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 228 <dir>฀ (Directory฀List)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 230 <div>฀ (Division)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 231 <dl>฀ (Definition฀List)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 233 <dt>฀ (Term฀in฀a฀Definition฀List฀or฀฀

(12)
(13)

<spacer>฀ (Extra฀Space)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 373 <span>฀ (Text฀Span)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 374 <strike>฀ (Strikeout฀Text)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 376 <strong>฀ (Strong฀Emphasis)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 377 <style>฀ (Style฀Information)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 379 <sub>฀ (Subscript)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 381 <sup>฀ (Superscript)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 383 <table>฀ (Table)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 385 <tbody>฀ (Table฀Body)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 389 <td>฀ (Table฀Data)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 392 <textarea>฀ (Multiline฀Text฀Input)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 396 <tfoot>฀ (Table฀Footer)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 399 <th>฀ (Table฀Header)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 402 <thead>฀ (Table฀Header)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 405 <time>฀ (Time)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 408 <title>฀ (Document฀Title)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 410 <tr>฀ (Table฀Row)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 411 <tt>฀ (Teletype฀Text)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 414 <u>฀ (Underline)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 415 <ul>฀ (Unordered฀List)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 417 <var>฀ (Variable)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 419 <video>฀ (Video)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 421 <wbr>฀ (Word฀Break)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 423 <xml>฀ (XML฀Data฀Island)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 424 <xmp>฀ (Example)฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 425

Part II

Core Style

4฀ Introduction฀to฀CSS฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 429

(14)

Document฀Structure฀and฀CSS฀Inheritance฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 468 !important฀Override฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 470 Selectors฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 470 Element฀Selectors฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 471 id฀Selectors฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 471 class฀Rules฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 473 Contextual฀Selection฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 476 Attribute฀Selectors฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 479 Pseudo-Element฀Selectors฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 484 Pseudo-Class฀Selectors฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 487 CSS฀Properties฀Preview฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 500 Measurements฀and฀Values฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 502 CSS฀and฀(X)HTML฀Elements฀Fundamentals฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 506 Physical฀Markup฀and฀Overriding฀Expected฀Results฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 506 Are฀<div>฀and฀<span>฀the฀Most฀Popular฀Tags?฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 507 Changing฀Element฀Types฀with฀display฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 508 Controlling฀White฀Space฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 512 Major฀Themes฀of฀CSS฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 513 Separation฀of฀Structure฀and฀Style฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 514 CSS:฀More฀Appropriate฀and฀Powerful฀for฀Presentation฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 516 Cross-Browser฀CSS฀Madness฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 517 Myths฀and฀Misconceptions฀Related฀to฀CSS฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 517 Summary฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 519

5฀ CSS฀Syntax฀and฀Property฀Reference฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 521

(15)
(16)

margin฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 581 margin-bottom฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 582 margin-left฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 582 margin-right฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 583 margin-top฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 583 max-height฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 584 max-width฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 584 min-height฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 585 min-width฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 585 orphans฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 586 outline฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 586 outline-color฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 588 outline-style฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 589 outline-width฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 590 overflow฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 590 padding฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 591 padding-bottom฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 593 padding-left฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 593 padding-right฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 594 padding-top฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 594 page-break-after฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 595 page-break-before฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 595 page-break-inside฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 596 position฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 596 quotes฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 597 right฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 598 table-layout฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 598 text-align฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 599 text-decoration฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 599 text-indent฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 600 text-transform฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 600 top฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 601 unicode-bidi฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 602 vertical-align฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 602 visibility฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 603 white-space฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 604 widows฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 604 width฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 605 word-spacing฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 606 z-index฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 607 CSS2฀and฀CSS฀2.1฀Aural฀Style฀Properties฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 607

6฀ CSS3฀Proprietary฀and฀Emerging฀Features฀Reference฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 613

(17)
(18)
(19)

transform-origin฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 715 transform-style฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 716 transition฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 717 transition-delay฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 717 transition-duration฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 718 transition-property฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 719 transition-timing-function฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 719 user-select฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 720 word-break฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 721 word-wrap฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 722 writing-mode฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 722 zoom฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 724

Part III

Appendixes

A฀ Character฀Entities฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 727

Encoding฀Quirks฀and฀Considerations฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 728 Traditional฀HTML฀Entities฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 731 HTML฀4.x฀and฀XHTML฀1.x฀Character฀Entities฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 740 Latin฀Extended-A฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 741 Latin฀Extended-B฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 741 Spacing฀Modifier฀Letters฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 741 General฀Punctuation฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 741 Greek฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 743 Letter-like฀Symbols฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 744 Arrows฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 745 Mathematical฀Operators฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 746 Technical฀Symbols฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 747 Geometric฀Shapes฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 748 Miscellaneous฀Symbols฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 748 Embracing฀Unicode฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 748

B฀ Fonts฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 751

Specifying฀Fonts฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 751 Fonts฀for฀Windows฀Platform฀and฀Browsers฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 752 Fonts฀for฀Macintosh฀System฀and฀Browsers฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 755 PC฀Mac฀Font฀Similarity฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 757 Downloadable฀Fonts฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 760 Microsoft’s฀Dynamic฀Fonts฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 760 Standard฀Downloadable฀Fonts฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 761 Cross-Browser฀Downloadable฀Fonts฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 761 Font฀Replacement฀with฀Images฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 763 sIFR฀and฀Other฀Text฀Replacement฀Techniques฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 764

C฀ Colors฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 765

(20)

CSS฀Color฀Values฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 773 CSS฀Color-Related฀Properties฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 776 Browser-Safe฀Colors฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 779

D฀ URLs฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 783

Basic฀Concepts฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 783 Server฀Address฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 784 Directory฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 786 Filename฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 787 Fragment฀Identifier฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 788 Protocol฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 788 Other฀Features฀of฀URLs฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 789 Data฀URIs฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 791 Other฀Emerging฀URL฀Forms฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 794 Relative฀URLs฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 795 Using฀the฀<base>฀Tag฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 795 URL฀Challenges฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 796 Unclear฀Case฀Sensitivity฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 797 Unclear฀Length฀Limits฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 797 Persistence฀Concerns฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 797 Long,฀Dirty฀URLs฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 797 Short,฀Cryptic฀URLs฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 797 Location,฀Not฀Meaning฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 798 Beyond฀URLs฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 798 New฀Addressing฀Schemes:฀URNs,฀URCs,฀and฀URIs฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 798

E฀ Reading฀a฀Document฀Type฀Definition฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 801

Element฀Type฀Declarations฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 801 Occurrence฀Indicators฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 802 Logical฀Connectors฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 803 SGML฀Content฀Exclusion฀and฀Inclusion฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 804 Attribute฀Declarations฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 804 SGML฀and฀XML฀Keywords฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 805 Parameter฀Entities฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 806 Comments฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 806 The฀DTDs฀ ฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀.฀฀ 807

(21)
(22)

T

he฀fifth฀edition฀of฀this฀book฀might฀as฀well฀be฀the฀first฀edition฀of฀a฀brand-new฀book.฀ The฀HTML5฀specification฀marks฀a฀return฀to฀past฀ideas฀and฀an฀explosion฀of฀future฀ ideas.฀It฀took฀a฀great฀deal฀of฀work฀to฀put฀this฀new฀edition฀together.฀Given฀the฀amount฀ of฀effort฀required,฀I฀want฀to฀make฀sure฀that฀all฀those฀that฀helped฀are฀given฀their฀due.฀First,฀I฀ want฀to฀acknowledge฀the฀numerous฀fixes฀and฀improvements฀that฀came฀from฀the฀feedback฀ from฀both฀my฀students฀at฀UCSD฀and฀readers฀around฀the฀world.฀I฀write฀these฀books฀for฀you,฀ and฀I฀am฀glad฀you฀are฀putting฀this฀information฀to฀good฀use.

I฀would฀also฀like฀to฀show฀my฀appreciation฀to฀the฀many฀staff฀members฀at฀PINT฀who฀ helped฀on฀this฀book฀project฀in฀some฀direct฀or฀indirect฀way.฀I฀can’t฀specifically฀thank฀and฀ mention฀the฀dozens฀of฀employees฀we฀have฀at฀PINT฀and฀my฀other฀firm฀Port80฀Software฀who฀ keep฀the฀lights฀on,฀but฀I’ll฀call฀a฀few฀out฀who฀warrant฀some฀extra฀kudos.

Christie฀Sorenson฀once฀again฀helped฀this฀time฀with฀heavy฀lifting฀particularly฀in฀the฀CSS฀ effort,฀and฀I฀can฀safely฀say฀that฀she฀has฀learned,฀relearned,฀and฀even฀forgotten฀more฀about฀ Web฀development฀than฀probably฀anyone฀I฀know,฀besides฀maybe฀myself.฀Looking฀forward฀to฀ more฀project฀fun฀in฀the฀future,฀Christie!

Plenty฀of฀other฀PINTsters฀helped.฀Rob฀McFarlane,฀Andrew฀Simpkins,฀and฀Bryan฀Sleiter฀ helped฀out฀with฀imagery.฀The฀project฀managers,฀particularly฀Mine฀Okano,฀Robin฀Nobel,฀ Matt฀Plotner,฀and฀Olivia฀Chen,฀gave฀me฀moral฀support฀and฀occasional฀pity฀as฀I฀toiled฀away฀ upstairs.฀Glenn฀Dawson฀addressed฀my฀many฀server฀changes฀and฀helped฀debug฀some฀ annoying฀aspects฀of฀HTML5.฀Dan฀Whitworth฀assisted฀on฀a฀few฀chapters฀here฀and฀there฀and฀ probably฀had฀nightmares฀about฀getting฀a฀call฀to฀really฀dive฀in.

Joe฀Lima฀listened฀to฀some฀of฀my฀verbal฀nonsense฀and฀helped฀guide฀me฀to฀some฀deeper฀ insights฀than฀I฀could฀have฀ever฀arrived฀at฀on฀my฀own.

Daisy฀Bhonsle฀kept฀up฀a฀very฀long-standing฀proofing฀relationship,฀and฀I฀am฀very฀glad฀ she฀always฀helps฀out.฀The฀student฀certainly฀has฀become฀the฀master.

The฀folks฀at฀McGraw-Hill฀Professional฀are฀always฀a฀pleasure฀to฀work฀with.฀Meghan฀ Riley฀helped฀guide฀me฀along,฀and฀Megg฀Morin฀didn’t฀lose฀faith,฀at฀least฀not฀completely.฀ Thanks฀for฀being฀my฀patron฀the฀last฀decade,฀Megg!

My฀technical฀editor,฀James฀Pence,฀probably฀wondered฀when฀this฀project฀was฀going฀to฀ finish,฀and฀somehow฀he฀finished฀a฀nontechnical฀book฀of฀his฀own฀during฀the฀project.

(23)

Finally,฀to฀my฀friends฀and฀family฀who฀tried฀to฀give฀me฀space฀to฀write฀this฀thing,฀you฀ deserve฀the฀biggest฀thanks.฀My฀children,฀Graham,฀Olivia,฀and฀Desmond,฀had฀to฀put฀up฀ with฀a฀grouchy฀dad฀and฀far฀too฀many฀absent฀weekends,฀so฀we฀now฀return฀you฀to฀our฀ regularly฀scheduled฀weekends!฀Cecilia,฀you฀provided฀a฀lot฀of฀help฀as฀well฀that฀made฀ things฀a฀bit฀easier฀on฀all฀of฀us,฀so฀thank฀you฀for฀that.฀Finally,฀Sylvia,฀you฀always฀support฀ my฀online฀efforts,฀as฀hard฀as฀they฀may฀be.฀I฀know฀you,฀more฀than฀anyone,฀appreciate฀the฀ importance฀of฀this฀project,฀considering฀the฀role฀HTML฀has฀played฀in฀our฀lives.

(24)

Introduction

T

he฀fifth฀edition฀of฀this฀book฀represents฀a฀significant฀change฀in฀structure฀and฀content฀to฀

address฀HTML5.฀The฀book฀is฀similar฀to฀the฀previous฀edition฀in฀maybe฀a฀third฀of฀the฀ content;฀otherwise,฀it฀is฀an฀all-new฀effort.฀Most฀obviously,฀as฀compared฀to฀the฀previous฀ editions,฀which฀focused฀mainly฀on฀XHTML฀and฀HTML฀4,฀this฀edition฀focuses฀on฀HTML5,฀ which฀represents฀both฀a฀return฀to฀the฀markup฀past฀and฀the฀unveiling฀of฀an฀exciting฀future฀of฀ Web฀applications.฀However,฀we฀do฀retain฀some฀information฀from฀previous฀editions฀because฀ in฀order฀for฀this฀work฀to฀be฀truly฀complete,฀we฀must฀not฀focus฀only฀on฀the฀future฀but฀also฀ present฀all฀the฀elements฀supported฀in฀browsers฀today,฀including฀the฀archaic,฀proprietary,฀and฀ standard฀(X)HTML฀tags.฀These฀will฀still฀be฀encountered฀for฀years฀to฀come,฀and฀we฀want฀this฀ book฀to฀provide฀the฀reference฀you฀need฀in฀addressing฀their฀syntax.

CSS฀coverage฀has฀been฀expanded฀greatly฀to฀fully฀cover฀CSS฀2.1฀as฀well฀as฀every฀proprietary฀ and฀emerging฀CSS฀3฀property฀supported฀in฀one฀or฀more฀popular฀shipping฀browsers฀circa฀2009.฀ No฀value฀judgment฀is฀made;฀if฀Internet฀Explorer฀has฀supported฀a฀proprietary฀CSS฀feature฀for฀ the฀last฀decade,฀it’s฀included.฀However,฀we฀do฀avoid฀presenting฀CSS฀features฀that฀are฀truly฀ speculative฀in฀great฀depth,฀but฀where฀appropriate,฀we฀summarize฀or฀present฀pointers฀to฀the฀ emerging฀syntax.

The฀ramification฀of฀the฀increased฀markup฀and฀CSS฀coverage฀is฀simply฀the฀book฀doesn’t฀ have฀space฀left฀to฀do฀everything฀it฀did฀before.฀Teaching฀nearly฀everything฀about฀HTML฀and฀ CSS฀in฀prose฀form฀and฀then฀presenting฀a฀complete฀syntax฀reference฀for฀the฀technologies฀ would฀have฀produced฀a฀book฀well฀over฀2,000฀pages.฀We฀were฀well฀on฀the฀way฀to฀that฀when฀ we฀adjusted฀our฀efforts฀to฀create฀what฀you฀have฀in฀your฀hands,฀a฀solid฀reference฀book฀that฀ may฀be฀used฀for฀years฀to฀come.฀This฀isn’t฀to฀say฀that฀learning฀material฀is฀not฀present฀at฀all.฀ There฀are฀very฀solid฀introductory฀chapters฀for฀the฀markup฀and฀CSS฀sections,฀which฀should฀ succinctly฀address฀details฀and฀standards฀issues.฀There฀just฀isn’t฀a฀step-by-step฀cookbook฀for฀ each฀element฀or฀property.฀Given฀the฀maturity฀of฀the฀Web฀industry,฀we฀aimed฀not฀for฀the฀ complete฀tutorial,฀but฀instead฀for฀the฀complete฀reference.

It฀should฀go฀without฀saying฀that฀more฀markup฀changes฀to฀HTML฀and฀CSS฀are฀inevitable.฀ HTML5,฀in฀particular,฀is฀a฀complete฀moving฀target,฀and฀rather฀than฀punting฀on฀it,฀we฀took฀ the฀best฀shot฀at฀its฀first฀release฀version฀as฀it฀settled฀in฀late฀2009.฀Because฀of฀the฀inevitable฀ changes฀given฀HTML5’s฀rapid฀evolution,฀the฀support฀Web฀site,฀http://htmlref.com,฀should฀ be฀considered฀an฀important฀bookmark฀for฀readers฀looking฀for฀updates฀or฀the฀unavoidable฀ correction.

(25)
(26)

I

Core Markup

C

HAPTER 1

Traditional฀HTML฀฀ and฀XHTML

C

HAPTER 2

Introducing฀HTML5

C

HAPTER 3

HTML฀and฀XHTML฀฀ Element฀Reference

(27)
(28)

1

Traditional HTML and XHTML

M

arkup฀languages฀are฀ubiquitous฀in฀everyday฀computing.฀Although฀you฀may฀not฀

realize฀it,฀word฀processing฀documents฀are฀filled฀with฀markup฀directives฀indicating฀ the฀structure฀and฀often฀presentation฀of฀the฀document.฀In฀the฀case฀of฀traditional฀ word฀processing฀documents,฀these฀structural฀and฀presentational฀markup฀codes฀are฀more฀ often฀than฀not฀behind฀the฀scenes.฀However,฀in฀the฀case฀of฀Web฀documents,฀markup฀in฀the฀form฀ of฀traditional฀Hypertext฀Markup฀Language฀(HTML)฀and฀its฀Extensible฀Markup฀Language฀ (XML)-focused฀variant,฀XHTML,฀is฀a฀little฀more฀obvious.฀These฀not-so-behind-the-scenes฀ markup฀languages฀are฀used฀to฀inform฀Web฀browsers฀about฀page฀structure฀and,฀some฀might฀ argue,฀presentation฀as฀well.

First Look at HTML and XHTML

In฀the฀case฀of฀HTML,฀markup฀instructions฀found฀within฀a฀Web฀page฀relay฀the฀structure฀of฀ the฀document฀to฀the฀browser฀software.฀For฀example,฀if฀you฀want฀to฀emphasize฀a฀portion฀of฀ text,฀you฀enclose฀it฀within฀the฀tags฀<em>฀and฀</em>,฀as฀shown฀here:

<em>This฀is฀important฀text!</em>

(29)

When฀a฀Web฀browser฀reads฀a฀document฀that฀has฀HTML฀markup฀in฀it,฀it฀determines฀how฀ to฀render฀it฀onscreen฀by฀considering฀the฀HTML฀elements฀embedded฀within฀the฀document:

So,฀an฀HTML฀document฀is฀simply฀a฀text฀file฀that฀contains฀the฀information฀you฀want฀to฀ publish฀and฀the฀appropriate฀markup฀instructions฀indicating฀how฀the฀browser฀should฀ structure฀or฀present฀the฀document.

Markup฀elements฀are฀made฀up฀of฀a฀start฀tag,฀such฀as฀<strong>,฀and฀typically,฀though฀not฀ always,฀an฀end฀tag,฀which฀is฀indicated฀by฀a฀slash฀within฀the฀tag,฀such฀as฀</strong>.฀The฀tag฀ pair฀should฀fully฀enclose฀any฀content฀to฀be฀affected฀by฀the฀element,฀including฀text฀and฀other฀ HTML฀markup.

N

OTE

There฀is฀a฀distinction฀between฀an฀element฀(for฀example,฀strong)฀and฀the฀tags฀(<strong> and฀</strong>)฀that฀are฀used฀by฀the฀element.฀However,฀you฀will฀likely฀often฀find฀the฀word฀ “tag”฀used฀in฀place฀of฀“element”฀in฀many฀if฀not฀most฀discussions฀about฀HTML฀markup.฀This฀ observation฀even฀includes฀historically฀relevant฀documents฀discussing฀HTML1฀written฀by฀Tim฀ Berners-Lee,฀the฀founding฀father฀of฀the฀Web.฀Fortunately,฀despite฀any฀imprecision฀of฀word฀choice฀ that฀people฀may฀exhibit฀when฀discussing฀markup,฀meaning฀is฀usually฀well฀understood฀and฀this฀ should฀not฀be฀a฀tremendous฀concern.

Under฀traditional฀HTML฀(not฀XHTML),฀the฀close฀tag฀for฀some฀elements฀is฀optional฀ because฀their฀closure฀can฀be฀inferred.฀For฀example,฀a฀<p>฀tag฀cannot฀enclose฀another฀<p>฀ tag,฀and฀thus฀the฀closing฀</p>฀tag฀can฀be฀inferred฀when฀markup฀like฀this฀is฀encountered:

<p>This฀is฀a฀paragraph.฀ <p>This฀is฀also฀a฀paragraph.

Such฀shortened฀notations฀that฀depend฀on฀inference฀may฀be฀technically฀correct฀under฀the฀ specification,฀but฀stylistically฀they฀are฀not฀encouraged.฀It฀is฀always฀preferable฀to฀be฀precise,฀ so฀use฀markup฀like฀this฀instead:

<p>This฀is฀a฀paragraph.</p><p>This฀is฀also฀a฀paragraph.</p>

1

(30)

PAR

T I

There฀are฀markup฀elements,฀called฀empty฀elements,฀which฀do฀not฀enclose฀any฀content,฀thus฀ need฀no฀close฀tags฀at฀all,฀or฀in฀the฀case฀of฀XHTML฀use฀a฀self-close฀identification฀scheme.฀For฀ example,฀to฀insert฀a฀line฀break,฀use฀a฀single฀<br>฀tag,฀which฀represents฀the฀empty฀br฀element,฀ because฀it฀doesn’t฀enclose฀any฀content฀and฀thus฀has฀no฀corresponding฀close฀tag:

<br>

However,฀in฀XML฀markup฀variants,฀particularly฀XHTML,฀an฀unclosed฀tag฀is฀not฀allowed,฀so฀ you฀need฀to฀close฀the฀tag

<br></br>

or,฀more฀commonly,฀use฀a฀self-identification฀of฀closure฀like฀so:

<br฀/>

The฀start฀tag฀of฀an฀element฀might฀contain฀attributes฀that฀modify฀the฀meaning฀of฀the฀tag.฀ For฀example,฀in฀HTML,฀the฀simple฀inclusion฀of฀the฀noshade฀attribute฀in฀an฀<hr>฀tag,฀as฀ shown฀here:

<hr฀noshade>

indicates฀that฀there฀should฀be฀no฀shading฀applied฀to฀this฀horizontal฀rule.฀Under฀XHTML,฀ such฀style฀attributes฀are฀not฀allowed,฀because฀all฀attributes฀must฀have฀a฀value,฀so฀instead฀ you฀have฀to฀use฀syntax฀like฀this:

<hr฀noshade="noshade"฀/>

As฀the฀preceding฀example฀shows,฀attributes฀may฀require฀values,฀which฀are฀specified฀with฀an฀ equal฀sign;฀these฀values฀should฀be฀enclosed฀within฀double฀or฀single฀quotes.฀For฀example,฀ using฀standard฀HTML฀syntax,

<img฀src="dog.gif"฀alt="Angus-Black฀Scottish฀Terrier"฀height="100"฀ width="100">

specifies฀four฀attributes฀for฀this฀<img>฀tag฀that฀are฀used฀to฀provide฀more฀information฀about฀ the฀use฀of฀the฀included฀image.฀Under฀traditional฀HTML,฀in฀the฀case฀of฀simple฀alphanumeric฀ attribute฀values,฀the฀use฀of฀quotes฀is฀optional,฀as฀shown฀here:

<p฀class=fancy>

(31)

A฀graphical฀overview฀of฀the฀HTML฀markup฀syntax฀shown฀so฀far฀is฀presented฀here:

Hello HTML and XHTML World

Given฀these฀basics฀of฀HTML฀syntax,฀it฀is฀best฀now฀to฀look฀at฀an฀example฀document฀to฀see฀its฀ <title>Hello฀HTML฀4฀World</title>฀

<!--฀Simple฀hello฀world฀in฀HTML฀4.01฀strict฀example฀-->฀ </head>฀

<body>

<h1>Welcome฀to฀the฀World฀of฀HTML</h1><hr>

<p>HTML฀<em>really</em>฀isn't฀so฀hard!</p>฀ <p>Soon฀you฀will฀&hearts;฀using฀HTML.</p><p>You฀can฀put฀lots฀of฀text฀here฀if฀you฀want.฀ We฀could฀go฀on฀and฀on฀with฀fake฀text฀for฀you฀ to฀read,฀but฀let's฀get฀back฀to฀the฀book.</p></body>฀

</html>

O

NLINE

http://htmlref.com/ch1/html4helloworld.html

A฀simple฀modification฀of฀the฀initial฀<!DOCTYPE>฀line฀is฀really฀all฀that฀is฀necessary฀to฀ make฀this฀an฀HTML5฀example,฀the฀comment฀and฀text฀is฀changed฀so฀you฀can฀keep฀the฀ <title>Hello฀HTML5฀World</title>฀

<!--฀Simple฀hello฀world฀in฀HTML5฀example฀--> </head>฀

<body>฀

<h1>Welcome฀to฀the฀Future฀World฀of฀HTML5</h1>฀ <hr>฀

<p>HTML5฀<em>really</em>฀isn't฀so฀hard!</p>฀

<h1 class=“primary”>Example Heading</h1> Tag

Name AttributeName

Attribute

Affected Content Start Tag

HTML Element Attribute

Value

(32)

PAR

T I

<p>Soon฀you฀will฀&hearts;฀using฀HTML.</p>฀ <p>You฀can฀put฀lots฀of฀text฀here฀if฀you฀want. We฀could฀go฀on฀and฀on฀with฀fake฀text฀for฀you to฀read,฀but฀let's฀get฀back฀to฀the฀book.</p>฀ </body>฀

</html>

O

NLINE

http://htmlref.com/ch1/html5helloworld.html

In฀the฀case฀of฀XHTML,฀which฀is฀a฀form฀of฀HTML฀that฀is฀based฀upon฀the฀syntax฀rules฀of฀ XML,฀we฀really฀don’t฀see฀many฀major฀changes฀yet฀in฀our฀example:

<!DOCTYPE฀html฀PUBLIC฀"-//W3C//DTD฀XHTML฀1.0฀Strict//EN"฀฀ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">฀ <html฀xmlns="http://www.w3.org/1999/xhtml">฀

<head>฀

<meta฀http-equiv="Content-Type"฀content="text/html;฀charset=utf-8"฀/>฀ <title>Hello฀XHTML฀World</title>฀

<!--฀Simple฀hello฀world฀in฀XHTML฀1.0฀strict฀example฀-->฀ </head>฀

<body>฀

<h1>Welcome฀to฀the฀World฀of฀XHTML</h1>฀ <hr฀/>฀

<p>XHTML฀<em>really</em>฀isn't฀so฀hard฀either!</p>฀ <p>Soon฀you฀will฀&hearts;฀using฀XHTML฀too.</p><p>There฀are฀some฀differences฀between฀XHTML฀ and฀HTML฀but฀with฀some฀precise฀markup฀you'll฀ see฀such฀differences฀are฀easily฀addressed.</p>฀ </body>฀

</html>

O

NLINE

http://htmlref.com/ch1/xhtmlhelloworld.html

The฀preceding฀examples฀use฀some฀of฀the฀most฀common฀elements฀used฀in฀(X)HTML฀ documents,฀including:

•฀ The฀<!DOCTYPE>฀statement,฀which฀indicates฀the฀particular฀version฀of฀HTML฀฀ or฀XHTML฀being฀used฀in฀the฀document.฀The฀first฀example฀uses฀the฀strict฀4.01฀ specification,฀the฀second฀uses฀a฀reduced฀form฀for฀HTML5฀the฀meaning฀of฀which฀ will฀be฀explained฀a฀bit฀later฀on,฀and฀the฀final฀example฀uses฀the฀XHTML฀1.0฀strict฀ specification.

•฀ The฀<html>,฀<head>,฀and฀<body>฀tag฀pairs฀are฀used฀to฀specify฀the฀general฀structure฀ of฀the฀document.฀The฀required฀inclusion฀of฀the฀xmlns฀attribute฀in฀the฀<html>฀tag฀is฀ a฀small฀difference฀required฀by฀XHTML.

•฀ The฀<meta>฀tag฀used฀in฀the฀examples฀indicates฀the฀MIME฀type฀of฀the฀document฀and฀ the฀character฀set฀in฀use.฀Notice฀that฀in฀the฀XHTML฀example,฀the฀element฀has฀a฀trailing฀ slash฀to฀indicate฀that฀it฀is฀an฀empty฀element.

•฀ The฀<title>฀and฀</title>฀tag฀pair฀specifies฀the฀title฀of฀the฀document,฀which฀ generally฀appears฀in฀the฀title฀bar฀of฀the฀Web฀browser.

Gambar

Table C-5. While these names are

Referensi

Dokumen terkait

Proofread the sentence to be sure that it has correct punctuation and that it has an independent clause with a complete subject and predicate..

Proofread the sentence to be sure that it has correct punctuation and that it has an independent clause with a complete subject and predicate.... Article Error You may need to

Pada saat menghadapi pasien dengan keadaan perdarahan di sekujur tubuhnya, hal pertama yang dapat dilakukan sebagai penanganan awal yang paling tepat adalah :.. Membersihkan

Seandainya seiring dengan isu kenaikkan Harga BBM naik dan bahkan sekarang sudah naik, gaji ayah dan ibu juga ikut naik, niscaya aku dan kawan-kawanku setiap hari akan

intelektual manusia yang telah diciptakan agar tidak diklaim atau di bajak oleh pihak lain.. Oleh karena pentingnya pengetahuan seputar HKI tersebut, mudah-mudahan

Untuk saat ini produsen rokok besar sudah memproduksi rokok mild, Gudang Garam ada Surya Signature, dari pihak Djarum lahir LA Light, yang cukup mengancam Sampoerna

Analisis konseptual akan mengantar kita pada setidaknya 2 hal penting: (1) memungkinkan kita melihat secara lebih jernih bagaimana suatu konsep terkait tidak

Kriteria inklusi adalah pasien dermatitis atopik yang baru pertama kali berobat di klinik kulit dan kelamin Rumah Sakit Margono Soekarjo Purwokerto periode Februari 2010 sampai