HTML SPEC
File an issue about the selected text
Living Standard — Last Updated 29 October 2021
Table of contents
- 1 Introduction
- 2 Common infrastructure
- 3 Semantics, structure, and APIs of HTML documents
- 4 The elements of HTML
- 5 Microdata
- 6 User interaction
- 7 Loading web pages
- 8 Web application APIs
- 9 Communication
- 10 Web workers
- 11 Worklets
- 12 Web storage
- 13 The HTML syntax
- 14 The XML syntax
- 15 Rendering
- 16 Obsolete features
- 17 IANA considerations
- Index
- References
- Acknowledgments
- Intellectual property rights
Full table of contents
- 1.1 Where does this specification fit?
- 1.2 Is this HTML5?
- 1.3 Background
- 1.4 Audience
- 1.5 Scope
- 1.6 History
- 1.8 HTML vs XML syntax
- 1.10 A quick introduction to HTML
- 1.10.1 Writing secure applications with HTML
- 1.10.2 Common pitfalls to avoid when using the scripting APIs
- 1.10.3 How to catch mistakes when writing HTML: validators and conformance checkers
- 1.11 Conformance requirements for authors
- 1.11.1 Presentational markup
- 1.11.2 Syntax errors
- 1.11.3 Restrictions on content models and on attribute values
- 1.12 Suggested reading
- 2.2 Policy-controlled features
2.7 Safe passing of structured data
- 2.7.1 Serializable objects
- 2.7.2 Transferable objects
- 2.7.3 StructuredSerializeInternal ( value, forStorage [ , memory ] )
- 2.7.4 StructuredSerialize ( value )
- 2.7.5 StructuredSerializeForStorage ( value )
- 2.7.6 StructuredDeserialize ( serialized, targetRealm [ , memory ] )
- 2.7.7 StructuredSerializeWithTransfer ( value, transferList )
- 2.7.8 StructuredDeserializeWithTransfer ( serializeWithTransferResult, targetRealm )
- 2.7.9 Performing serialization and transferring from other specifications
- 2.7.10 Structured cloning API
- 4.3.1 The
body
element - 4.3.2 The
article
element - 4.3.3 The
section
element - 4.3.4 The
nav
element - 4.3.5 The
aside
element - 4.3.6 The
h1
,h2
,h3
,h4
,h5
, andh6
elements - 4.3.7 The
hgroup
element - 4.3.8 The
header
element - 4.3.9 The
footer
element - 4.3.10 The
address
element - 4.3.11 Headings and sections
- 4.3.11.1 Creating an outline
- 4.3.11.2 Sample outlines
- 4.3.11.3 Exposing outlines to users
- 4.3.12 Usage summary
- 4.3.12.1 Article or section?
- 4.3.1 The
- 4.4.1 The
p
element - 4.4.2 The
hr
element - 4.4.3 The
pre
element - 4.4.4 The
blockquote
element - 4.4.5 The
ol
element - 4.4.6 The
ul
element - 4.4.7 The
menu
element - 4.4.8 The
li
element - 4.4.9 The
dl
element - 4.4.10 The
dt
element - 4.4.11 The
dd
element - 4.4.12 The
figure
element - 4.4.13 The
figcaption
element - 4.4.14 The
main
element - 4.4.15 The
div
element
- 4.4.1 The
- 4.5.1 The
a
element - 4.5.2 The
em
element - 4.5.3 The
strong
element - 4.5.4 The
small
element - 4.5.5 The
s
element - 4.5.6 The
cite
element - 4.5.7 The
q
element - 4.5.8 The
dfn
element - 4.5.9 The
abbr
element - 4.5.10 The
ruby
element - 4.5.11 The
rt
element - 4.5.12 The
rp
element - 4.5.13 The
data
element - 4.5.14 The
time
element - 4.5.15 The
code
element - 4.5.16 The
var
element - 4.5.17 The
samp
element - 4.5.18 The
kbd
element - 4.5.19 The
sub
andsup
elements - 4.5.20 The
i
element - 4.5.21 The
b
element - 4.5.22 The
u
element - 4.5.23 The
mark
element - 4.5.24 The
bdi
element - 4.5.25 The
bdo
element - 4.5.26 The
span
element - 4.5.27 The
br
element - 4.5.28 The
wbr
element - 4.5.29 Usage summary
- 4.5.1 The
- 4.6.1 Introduction
- 4.6.2 Links created by
a
andarea
elements - 4.6.3 API for
a
andarea
elements - 4.6.4 Following hyperlinks
- 4.6.6.1 Link type "
alternate
" - 4.6.6.2 Link type "
author
" - 4.6.6.3 Link type "
bookmark
" - 4.6.6.4 Link type "
canonical
" - 4.6.6.5 Link type "
dns-prefetch
" - 4.6.6.6 Link type "
external
" - 4.6.6.7 Link type "
help
" - 4.6.6.8 Link type "
icon
" - 4.6.6.9 Link type "
license
" - 4.6.6.10 Link type "
manifest
" - 4.6.6.11 Link type "
modulepreload
" - 4.6.6.12 Link type "
nofollow
" - 4.6.6.13 Link type "
noopener
" - 4.6.6.14 Link type "
noreferrer
" - 4.6.6.15 Link type "
opener
" - 4.6.6.16 Link type "
pingback
" - 4.6.6.17 Link type "
preconnect
" - 4.6.6.18 Link type "
prefetch
" - 4.6.6.19 Link type "
preload
" - 4.6.6.20 Link type "
prerender
" - 4.6.6.21 Link type "
search
" - 4.6.6.22 Link type "
stylesheet
" - 4.6.6.23 Link type "
tag
" - 4.6.6.24 Sequential link types
- 4.6.6.24.1 Link type "
next
" - 4.6.6.24.2 Link type "
prev
" - 4.6.6.25 Other link types
- 4.6.6.1 Link type "
- 4.8.1 The
picture
element - 4.8.2 The
source
element - 4.8.3 The
img
element - 4.8.4.3.1 When to obtain images
- 4.8.4.3.2 Reacting to DOM mutations
- 4.8.4.3.3 The list of available images
- 4.8.4.3.4 Decoding images
- 4.8.4.3.5 Updating the image data
- 4.8.4.3.6 Preparing an image for presentation
- 4.8.4.3.7 Selecting an image source
- 4.8.4.3.8 Updating the source set
- 4.8.4.3.9 Parsing a srcset attribute
- 4.8.4.3.10 Parsing a sizes attribute
- 4.8.4.3.11 Normalizing the source densities
- 4.8.4.3.12 Reacting to environment changes
4.8.4.4 Requirements for providing text to act as an alternative for images
- 4.8.4.4.1 General guidelines
- 4.8.4.4.2 A link or button containing nothing but the image
- 4.8.4.4.3 A phrase or paragraph with an alternative graphical representation: charts, diagrams, graphs, maps, illustrations
- 4.8.4.4.4 A short phrase or label with an alternative graphical representation: icons, logos
- 4.8.4.4.5 Text that has been rendered to a graphic for typographical effect
- 4.8.4.4.6 A graphical representation of some of the surrounding text
- 4.8.4.4.7 Ancillary images
- 4.8.4.4.8 A purely decorative image that doesn't add any information
- 4.8.4.4.9 A group of images that form a single larger picture with no links
- 4.8.4.4.10 A group of images that form a single larger picture with links
- 4.8.4.4.11 A key part of the content
- 4.8.4.4.12 An image not intended for the user
- 4.8.4.4.13 An image in an email or private document intended for a specific person who is known to be able to view images
- 4.8.4.4.14 Guidance for markup generators
- 4.8.4.4.15 Guidance for conformance checkers
- 4.8.5 The
iframe
element - 4.8.6 The
embed
element - 4.8.7 The
object
element - 4.8.8 The
param
element - 4.8.9 The
video
element - 4.8.10 The
audio
element - 4.8.11 The
track
element - 4.8.12 Media elements
- 4.8.12.1 Error codes
- 4.8.12.2 Location of the media resource
- 4.8.12.3 MIME types
- 4.8.12.4 Network states
- 4.8.12.5 Loading the media resource
- 4.8.12.6 Offsets into the media resource
- 4.8.12.7 Ready states
- 4.8.12.8 Playing the media resource
- 4.8.12.9 Seeking
- 4.8.12.10 Media resources with multiple media tracks
- 4.8.12.10.1
AudioTrackList
andVideoTrackList
objects - 4.8.12.10.2 Selecting specific audio and video tracks declaratively
- 4.8.12.11 Timed text tracks
- 4.8.12.11.1 Text track model
- 4.8.12.11.2 Sourcing in-band text tracks
- 4.8.12.11.3 Sourcing out-of-band text tracks
- 4.8.12.11.4 Guidelines for exposing cues in various formats as text track cues
- 4.8.12.11.5 Text track API
- 4.8.12.11.6 Event handlers for objects of the text track APIs
- 4.8.12.11.7 Best practices for metadata text tracks
- 4.8.12.12 Identifying a track kind through a URL
- 4.8.12.13 User interface
- 4.8.12.14 Time ranges
- 4.8.12.15 The
TrackEvent
interface - 4.8.12.16 Events summary
- 4.8.12.17 Security and privacy considerations
- 4.8.12.18 Best practices for authors using media elements
- 4.8.12.19 Best practices for implementers of media elements
- 4.8.13 The
map
element - 4.8.14 The
area
element - 4.8.15 Image maps
- 4.8.15.1 Authoring
- 4.8.15.2 Processing model
- 4.8.16 MathML
- 4.8.17 SVG
- 4.8.18 Dimension attributes
- 4.8.1 The
- 4.9.2 The
caption
element - 4.9.3 The
colgroup
element - 4.9.4 The
col
element - 4.9.5 The
tbody
element - 4.9.6 The
thead
element - 4.9.7 The
tfoot
element - 4.9.8 The
tr
element - 4.9.9 The
td
element - 4.9.10 The
th
element - 4.9.11 Attributes common to
td
andth
elements - 4.9.12 Processing model
- 4.9.12.1 Forming a table
- 4.9.12.2 Forming relationships between data cells and header cells
- 4.9.13 Examples
- 4.10 Forms
- 4.10.1.1 Writing a form's user interface
- 4.10.1.2 Implementing the server-side processing for a form
- 4.10.1.3 Configuring a form to communicate with a server
- 4.10.1.4 Client-side form validation
- 4.10.1.5 Enabling client-side automatic filling of form controls
- 4.10.1.6 Improving the user experience on mobile devices
- 4.10.1.7 The difference between the field type, the autofill field name, and the input modality
- 4.10.1.8 Date, time, and number formats
- 4.10.2 Categories
- 4.10.3 The
form
element - 4.10.4 The
label
element 4.10.5.1 States of the
type
attribute- 4.10.5.1.1 Hidden state (
type=hidden
) - 4.10.5.1.2 Text (
type=text
) state and Search state (type=search
) - 4.10.5.1.3 Telephone state (
type=tel
) - 4.10.5.1.4 URL state (
type=url
) - 4.10.5.1.5 Email state (
type=email
) - 4.10.5.1.6 Password state (
type=password
) - 4.10.5.1.7 Date state (
type=date
) - 4.10.5.1.8 Month state (
type=month
) - 4.10.5.1.9 Week state (
type=week
) - 4.10.5.1.10 Time state (
type=time
) - 4.10.5.1.11 Local Date and Time state (
type=datetime-local
) - 4.10.5.1.12 Number state (
type=number
) - 4.10.5.1.13 Range state (
type=range
) - 4.10.5.1.14 Color state (
type=color
) - 4.10.5.1.15 Checkbox state (
type=checkbox
) - 4.10.5.1.16 Radio Button state (
type=radio
) - 4.10.5.1.17 File Upload state (
type=file
) - 4.10.5.1.18 Submit Button state (
type=submit
) - 4.10.5.1.19 Image Button state (
type=image
) - 4.10.5.1.20 Reset Button state (
type=reset
) - 4.10.5.1.21 Button state (
type=button
)
- 4.10.5.1.1 Hidden state (
- 4.10.5.2 Implementation notes regarding localization of form controls
4.10.5.3 Common
input
element attributes- 4.10.5.3.1 The
maxlength
andminlength
attributes - 4.10.5.3.2 The
size
attribute - 4.10.5.3.3 The
readonly
attribute - 4.10.5.3.4 The
required
attribute - 4.10.5.3.5 The
multiple
attribute - 4.10.5.3.6 The
pattern
attribute - 4.10.5.3.7 The
min
andmax
attributes - 4.10.5.3.8 The
step
attribute - 4.10.5.3.9 The
list
attribute - 4.10.5.3.10 The
placeholder
attribute
- 4.10.5.3.1 The
- 4.10.5.4 Common
input
element APIs - 4.10.5.5 Common event behaviors
- 4.10.6 The
button
element - 4.10.7 The
select
element - 4.10.8 The
datalist
element - 4.10.9 The
optgroup
element - 4.10.10 The
option
element - 4.10.11 The
textarea
element - 4.10.12 The
output
element - 4.10.13 The
progress
element - 4.10.14 The
meter
element - 4.10.15 The
fieldset
element - 4.10.16 The
legend
element - 4.10.17 Form control infrastructure
- 4.10.17.1 A form control's value
- 4.10.17.2 Mutability
- 4.10.17.3 Association of controls and forms
- 4.10.18 Attributes common to form controls
- 4.10.18.1 Naming form controls: the
name
attribute - 4.10.18.2 Submitting element directionality: the
dirname
attribute - 4.10.18.3 Limiting user input length: the
maxlength
attribute - 4.10.18.4 Setting minimum input length requirements: the
minlength
attribute - 4.10.18.5 Enabling and disabling form controls: the
disabled
attribute - 4.10.18.6 Form submission attributes
- 4.10.19 APIs for the text control selections
- 4.10.20 Constraints
- 4.10.20.1 Definitions
- 4.10.20.2 Constraint validation
- 4.10.20.3 The constraint validation API
- 4.10.20.4 Security
- 4.10.21 Form submission
- 4.10.21.1 Introduction
- 4.10.21.2 Implicit submission
- 4.10.21.3 Form submission algorithm
- 4.10.21.4 Constructing the entry list
- 4.10.21.5 Selecting a form submission encoding
- 4.10.21.6 Converting an entry list to a list of name-value pairs
- 4.10.21.7 URL-encoded form data
- 4.10.21.8 Multipart form data
- 4.10.21.9 Plain text form data
- 4.10.21.10 The
SubmitEvent
interface - 4.10.21.11 The
FormDataEvent
interface - 4.10.22 Resetting a form
- 4.11 Interactive elements
- 4.11.1 The
details
element - 4.11.2 The
summary
element - 4.11.3.1 Facets
- 4.11.3.2 Using the
a
element to define a command - 4.11.3.3 Using the
button
element to define a command - 4.11.3.4 Using the
input
element to define a command - 4.11.3.5 Using the
option
element to define a command - 4.11.3.6 Using the
accesskey
attribute on alegend
element to define a command - 4.11.3.7 Using the
accesskey
attribute to define a command on other elements
- 4.11.4 The
dialog
element - 4.12 Scripting
- 4.12.2 The
noscript
element - 4.12.4 The
slot
element 4.12.5.1 The 2D rendering context
- 4.12.5.1.1 Implementation notes
- 4.12.5.1.2 The canvas state
- 4.12.5.1.3 Line styles
- 4.12.5.1.4 Text styles
- 4.12.5.1.5 Building paths
- 4.12.5.1.6
Path2D
objects - 4.12.5.1.7 Transformations
- 4.12.5.1.8 Image sources for 2D rendering contexts
- 4.12.5.1.9 Fill and stroke styles
- 4.12.5.1.10 Drawing rectangles to the bitmap
- 4.12.5.1.11 Drawing text to the bitmap
- 4.12.5.1.12 Drawing paths to the canvas
- 4.12.5.1.13 Drawing focus rings and scrolling paths into view
- 4.12.5.1.14 Drawing images
- 4.12.5.1.15 Pixel manipulation
- 4.12.5.1.16 Compositing
- 4.12.5.1.17 Image smoothing
- 4.12.5.1.18 Shadows
- 4.12.5.1.19 Filters
- 4.12.5.1.20 Working with externally-defined SVG filters
- 4.12.5.1.21 Drawing model
- 4.12.5.1.22 Best practices
- 4.12.5.1.23 Examples
- 4.12.5.4 Color spaces and color space conversion
- 4.12.5.5 Serializing bitmaps to a file
- 4.12.5.6 Security with
canvas
elements - 4.12.5.7 Premultiplied alpha and the 2D rendering context
- 4.13 Custom elements
- 4.13.1.1 Creating an autonomous custom element
- 4.13.1.2 Creating a form-associated custom element
- 4.13.1.3 Creating a custom element with default accessible roles, states, and properties
- 4.13.1.4 Creating a customized built-in element
- 4.13.1.5 Drawbacks of autonomous custom elements
- 4.13.1.6 Upgrading elements after their creation
- 4.13.2 Requirements for custom element constructors and reactions
- 4.13.3 Core concepts
- 4.13.4 The
CustomElementRegistry
interface - 4.13.5 Upgrades
- 4.13.6 Custom element reactions
- 4.14 Common idioms without dedicated elements
- 4.14.1 Breadcrumb navigation
- 4.14.2 Tag clouds
- 4.14.3 Conversations
- 4.14.4 Footnotes
- 4.15 Disabled elements
- 4.16 Matching HTML elements using selectors and CSS
- 4.16.1 Case-sensitivity of the CSS 'attr()' function
- 4.16.2 Case-sensitivity of selectors
- 4.16.3 Pseudo-classes
- 6.1 The
hidden
attribute - 6.2 Inert subtrees
- 6.4 Activation behavior of elements
- 6.7.1 Making document regions editable: The
contenteditable
content attribute - 6.7.2 Making entire documents editable: the
designMode
getter and setter - 6.7.3 Best practices for in-page editors
- 6.7.4 Editing APIs
- 6.7.5 Spelling and grammar checking
- 6.7.6 Autocapitalization
- 6.7.7 Input modalities: the
inputmode
attribute - 6.7.8 Input modalities: the
enterkeyhint
attribute
- 6.7.1 Making document regions editable: The
- 6.1 The
7.2 Security infrastructure for
Window
,WindowProxy
, andLocation
objects- 7.6 Sandboxing
- 7.9 Policy containers
- 7.10 Session history and navigation
- 7.10.1 Browsing sessions
- 7.10.2 The session history of browsing contexts
- 7.10.3 The
History
interface - 7.10.4 Implementation notes for session history
- 7.10.5.1 [[GetPrototypeOf]] ( )
- 7.10.5.2 [[SetPrototypeOf]] ( V )
- 7.10.5.3 [[IsExtensible]] ( )
- 7.10.5.4 [[PreventExtensions]] ( )
- 7.10.5.5 [[GetOwnProperty]] ( P )
- 7.10.5.6 [[DefineOwnProperty]] ( P, Desc )
- 7.10.5.7 [[Get]] ( P, Receiver )
- 7.10.5.8 [[Set]] ( P, V, Receiver )
- 7.10.5.9 [[Delete]] ( P )
- 7.10.5.10 [[OwnPropertyKeys]] ( )
- 7.11 Browsing the web
- 7.11.1 Navigating across documents
- 7.11.2 Page load processing model for HTML files
- 7.11.3 Page load processing model for XML files
- 7.11.4 Page load processing model for text files
- 7.11.5 Page load processing model for
multipart/x-mixed-replace
resources - 7.11.6 Page load processing model for media
- 7.11.7 Page load processing model for content that uses plugins
- 7.11.8 Page load processing model for inline content that doesn't have a DOM
- 7.11.9 Navigating to a fragment
- 7.11.10 History traversal
- 7.11.10.1 Persisted history entry state
- 7.11.10.2 The
PopStateEvent
interface - 7.11.10.3 The
HashChangeEvent
interface - 7.11.10.4 The
PageTransitionEvent
interface - 7.11.11 Loading documents
- 7.11.12 Unloading documents
- 7.11.12.1 The
BeforeUnloadEvent
interface - 7.11.13 Aborting a document load
- 7.11.14 The `
X-Frame-Options
` header
- 8.2 The
WindowOrWorkerGlobalScope
mixin - 8.3 Base64 utility methods
- 8.5 DOM parsing
- 8.6 Timers
- 8.7 Microtask queuing
- 8.10 Images
- 8.11 Animation frames
- 10 Web workers
- 11 Worklets
- 12 Web storage
- 12.1 Introduction
- 13 The HTML syntax
- 13.2.1 Overview of the parsing model
- 13.2.2 Parse errors
- 13.2.5.1 Data state
- 13.2.5.2 RCDATA state
- 13.2.5.3 RAWTEXT state
- 13.2.5.4 Script data state
- 13.2.5.5 PLAINTEXT state
- 13.2.5.6 Tag open state
- 13.2.5.7 End tag open state
- 13.2.5.8 Tag name state
- 13.2.5.9 RCDATA less-than sign state
- 13.2.5.10 RCDATA end tag open state
- 13.2.5.11 RCDATA end tag name state
- 13.2.5.12 RAWTEXT less-than sign state
- 13.2.5.13 RAWTEXT end tag open state
- 13.2.5.14 RAWTEXT end tag name state
- 13.2.5.15 Script data less-than sign state
- 13.2.5.16 Script data end tag open state
- 13.2.5.17 Script data end tag name state
- 13.2.5.18 Script data escape start state
- 13.2.5.19 Script data escape start dash state
- 13.2.5.20 Script data escaped state
- 13.2.5.21 Script data escaped dash state
- 13.2.5.22 Script data escaped dash dash state
- 13.2.5.23 Script data escaped less-than sign state
- 13.2.5.24 Script data escaped end tag open state
- 13.2.5.25 Script data escaped end tag name state
- 13.2.5.26 Script data double escape start state
- 13.2.5.27 Script data double escaped state
- 13.2.5.28 Script data double escaped dash state
- 13.2.5.29 Script data double escaped dash dash state
- 13.2.5.30 Script data double escaped less-than sign state
- 13.2.5.31 Script data double escape end state
- 13.2.5.32 Before attribute name state
- 13.2.5.33 Attribute name state
- 13.2.5.34 After attribute name state
- 13.2.5.35 Before attribute value state
- 13.2.5.36 Attribute value (double-quoted) state
- 13.2.5.37 Attribute value (single-quoted) state
- 13.2.5.38 Attribute value (unquoted) state
- 13.2.5.39 After attribute value (quoted) state
- 13.2.5.40 Self-closing start tag state
- 13.2.5.41 Bogus comment state
- 13.2.5.42 Markup declaration open state
- 13.2.5.43 Comment start state
- 13.2.5.44 Comment start dash state
- 13.2.5.45 Comment state
- 13.2.5.46 Comment less-than sign state
- 13.2.5.47 Comment less-than sign bang state
- 13.2.5.48 Comment less-than sign bang dash state
- 13.2.5.49 Comment less-than sign bang dash dash state
- 13.2.5.50 Comment end dash state
- 13.2.5.51 Comment end state
- 13.2.5.52 Comment end bang state
- 13.2.5.53 DOCTYPE state
- 13.2.5.54 Before DOCTYPE name state
- 13.2.5.55 DOCTYPE name state
- 13.2.5.56 After DOCTYPE name state
- 13.2.5.57 After DOCTYPE public keyword state
- 13.2.5.58 Before DOCTYPE public identifier state
- 13.2.5.59 DOCTYPE public identifier (double-quoted) state
- 13.2.5.60 DOCTYPE public identifier (single-quoted) state
- 13.2.5.61 After DOCTYPE public identifier state
- 13.2.5.62 Between DOCTYPE public and system identifiers state
- 13.2.5.63 After DOCTYPE system keyword state
- 13.2.5.64 Before DOCTYPE system identifier state
- 13.2.5.65 DOCTYPE system identifier (double-quoted) state
- 13.2.5.66 DOCTYPE system identifier (single-quoted) state
- 13.2.5.67 After DOCTYPE system identifier state
- 13.2.5.68 Bogus DOCTYPE state
- 13.2.5.69 CDATA section state
- 13.2.5.70 CDATA section bracket state
- 13.2.5.71 CDATA section end state
- 13.2.5.72 Character reference state
- 13.2.5.73 Named character reference state
- 13.2.5.74 Ambiguous ampersand state
- 13.2.5.75 Numeric character reference state
- 13.2.5.76 Hexadecimal character reference start state
- 13.2.5.77 Decimal character reference start state
- 13.2.5.78 Hexadecimal character reference state
- 13.2.5.79 Decimal character reference state
- 13.2.5.80 Numeric character reference end state
- 13.2.6.1 Creating and inserting nodes
- 13.2.6.2 Parsing elements that contain only text
- 13.2.6.3 Closing elements that have implied end tags
13.2.6.4 The rules for parsing tokens in HTML content
- 13.2.6.4.1 The "initial" insertion mode
- 13.2.6.4.2 The "before html" insertion mode
- 13.2.6.4.3 The "before head" insertion mode
- 13.2.6.4.4 The "in head" insertion mode
- 13.2.6.4.5 The "in head noscript" insertion mode
- 13.2.6.4.6 The "after head" insertion mode
- 13.2.6.4.7 The "in body" insertion mode
- 13.2.6.4.8 The "text" insertion mode
- 13.2.6.4.9 The "in table" insertion mode
- 13.2.6.4.10 The "in table text" insertion mode
- 13.2.6.4.11 The "in caption" insertion mode
- 13.2.6.4.12 The "in column group" insertion mode
- 13.2.6.4.13 The "in table body" insertion mode
- 13.2.6.4.14 The "in row" insertion mode
- 13.2.6.4.15 The "in cell" insertion mode
- 13.2.6.4.16 The "in select" insertion mode
- 13.2.6.4.17 The "in select in table" insertion mode
- 13.2.6.4.18 The "in template" insertion mode
- 13.2.6.4.19 The "after body" insertion mode
- 13.2.6.4.20 The "in frameset" insertion mode
- 13.2.6.4.21 The "after frameset" insertion mode
- 13.2.6.4.22 The "after after body" insertion mode
- 13.2.6.4.23 The "after after frameset" insertion mode
- 13.2.6.5 The rules for parsing tokens in foreign content
- 13.2.7 The end
- 13.2.8 Speculative HTML parsing
- 13.2.9 Coercing an HTML DOM into an infoset
- 13.2.10 An introduction to error handling and strange cases in the parser
- 13.2.10.1 Misnested tags:
- 13.2.10.2 Misnested tags:
- 13.2.10.3 Unexpected markup in tables
- 13.2.10.4 Scripts that modify the page as it is being parsed
- 13.2.10.5 The execution of scripts that are moving across multiple documents
- 13.2.10.6 Unclosed formatting elements
- 13.3 Serializing HTML fragments
- 13.4 Parsing HTML fragments
- 13.5 Named character references
- 14 The XML syntax
- 14.1 Writing documents in the XML syntax
- 14.2 Parsing XML documents
- 14.3 Serializing XML fragments
- 14.4 Parsing XML fragments
- 15 Rendering
- 15.1 Introduction
- 15.2 The CSS user agent style sheet and presentational hints
- 15.5.1 Introduction
- 15.5.2 Button layout
- 15.5.3 The
button
element - 15.5.4 The
details
andsummary
elements - 15.5.5 The
input
element as a text entry widget - 15.5.6 The
input
element as domain-specific widgets - 15.5.7 The
input
element as a range control - 15.5.8 The
input
element as a color well - 15.5.9 The
input
element as a checkbox and radio button widgets - 15.5.10 The
input
element as a file upload control - 15.5.11 The
input
element as a button - 15.5.12 The
marquee
element - 15.5.13 The
meter
element - 15.5.14 The
progress
element - 15.5.15 The
select
element - 15.5.16 The
textarea
element
- 15.6 Frames and framesets
- 15.8 Print media
- 15.9 Unstyled XML documents
- 16 Obsolete features
- 16.2 Non-conforming features
- 17 IANA considerations
- 17.1
text/html
- 17.2
multipart/x-mixed-replace
- 17.3
application/xhtml+xml
- 17.4
text/ping
- 17.5
application/microdata+json
- 17.6
text/event-stream
- 17.7 `
Cross-Origin-Embedder-Policy
` - 17.8 `
Cross-Origin-Embedder-Policy-Report-Only
` - 17.9 `
Cross-Origin-Opener-Policy
` - 17.10 `
Cross-Origin-Opener-Policy-Report-Only
` - 17.11 `
Origin-Agent-Cluster
` - 17.12 `
Ping-From
` - 17.13 `
Ping-To
` - 17.14 `
Refresh
` - 17.15 `
Last-Event-ID
` - 17.16 `
X-Frame-Options
` - 17.17
web+
scheme prefix - Index
- Elements
- Element content categories
- Attributes
- Element Interfaces
- All Interfaces
- Events
- MIME Types
- References
- Acknowledgments
- Intellectual property rights