11. Obsolete features
11.1. Obsolete but conforming features
Features listed in this section will trigger warnings in conformance checkers.
Authors should not specify a border attribute on an img element. If the
  attribute is present, its value must be the string "0". CSS should be used instead.
Authors should not specify a language attribute on a script element. If
  the attribute is present, its value must be an ASCII case-insensitive match for the string
  "JavaScript" and either the type attribute must be omitted or its value
  must be an ASCII case-insensitive match for the string "text/javascript".
  The attribute should be entirely omitted instead (with the value "JavaScript", it has
  no effect), or replaced with use of the type attribute.
Authors should not specify the name attribute on a elements. If the
  attribute is present, its value must not be the empty string and must neither be equal to the
  value of any of the IDs in the element’s tree other than the element’s own ID if any, nor be equal to the value of any of the other name attributes on a elements in the element’s tree. If this attribute is present and the
  element has an ID, then the attribute’s value must be equal to the element’s ID. In
  earlier versions of the language, this attribute was intended as a way to specify possible targets
  for fragments in URLs. The id attribute should be used instead.
Authors should not, but may despite requirements to the contrary elsewhere in this specification,
  specify the maxlength and size attributes on input elements
  whose type attributes are in the Number state. One
  valid reason for using these attributes regardless is to help legacy user agents that do not
  support input elements with type="number" to still render the text control with a
  useful width.
11.1.1. Warnings for obsolete but conforming features
To ease the transition from HTML Transitional documents to the language defined in this specification, and to discourage certain features that are only allowed in very few circumstances, conformance checkers must warn the user when the following features are used in a document. These are generally old obsolete features that have no effect, and are allowed only to distinguish between likely mistakes (regular conformance errors) and mere vestigial markup or unusual and discouraged practices (these warnings).
The following features must be categorized as described above:
- 
      The presence of a borderattribute on animgelement if its value is the string "0".
- 
      The presence of a languageattribute on ascriptelement if its value is an ASCII case-insensitive match for the string "JavaScript" and if there is notypeattribute or there is and its value is an ASCII case-insensitive match for the string "text/javascript".
- 
      The presence of a nameattribute on anaelement, if its value is not the empty string.
- 
      The presence of a maxlengthattribute on aninputelement whosetypeattribute is in theNumberstate.
- 
      The presence of a sizeattribute on aninputelement whosetypeattribute is in theNumberstate.
Conformance checkers must distinguish between pages that have no conformance errors and have none of these obsolete features, and pages that have no conformance errors but do have some of these obsolete features.
For example, a validator could report some pages as "Valid HTML" and others as "Valid HTML with warnings".
11.2. Non-conforming features
Elements in the following list are entirely obsolete, and must not be used by authors:
- applet
- acronym
- 
      Use abbrinstead.
- bgsound
- 
      Use audioinstead.
- dir
- 
      Use ulinstead.
- frame
- frameset
- noframes
- 
      Either use iframeand CSS instead, or use server-side includes to generate complete pages with the various invariant parts merged in.
- isindex
- 
      Use an explicit formandtext controlcombination instead.
- listing
- nextid
- 
      Use GUIDs instead. 
- noembed
- plaintext
- 
      Use the " text/plain" MIME type instead.
- rb
- rtc
- 
      Providing the ruby base directly inside the rubyelement or using nestedrubyelements is sufficient.
- strike
- 
      Use delinstead if the element is marking an edit, otherwise usesinstead.
- xmp
- 
      Use preandcodeinstead, and escape "<" and "&" characters as "<" and "&" respectively.
- basefont
- big
- blink
- center
- font
- marquee
- multicol
- nobr
- spacer
- tt
- 
      Use appropriate elements or CSS instead. Where the ttelement would have been used for marking up keyboard input, consider thekbdelement; for variables, consider thevarelement; for computer code, consider thecodeelement; and for computer output, consider thesampelement.Similarly, if the bigelement is being used to denote a heading, consider using theh1element; if it is being used for marking up important passages, consider thestrongelement; and if it is being used for highlighting text for reference purposes, consider themarkelement.See also the text-level semantics usage summary for more suggestions with examples. 
The following attributes are obsolete (though the elements are still part of the language), and must not be used by authors:
- charseton- aelements
- charseton- linkelements
- 
      Use an HTTP Content-Typeheader on the linked resource instead.
- coordson- aelements
- shapeon- aelements
- 
      Use areainstead ofafor image maps.
- methodson- aelements
- methodson- linkelements
- 
      Use the HTTP OPTIONS feature instead. 
- nameon- aelements (except as noted in the previous section)
- nameon- embedelements
- nameon- imgelements
- nameon- optionelements
- 
      Use the idattribute instead.
- revon- aelements
- revon- linkelements
- 
      Use the relattribute instead, with an opposite term. (For example, instead of rev="made", use rel="author".)
- urnon- aelements
- urnon- linkelements
- 
      Specify the preferred persistent identifier using the hrefattribute instead.
- accepton- formelements
- 
      Use the acceptattribute directly on theinputelements instead.
- hreflangon- areaelements
- typeon- areaelements
- 
      These attributes do not do anything useful, and for historical reasons there are no corresponding IDL attributes on areaelements. Omit them altogether.
- nohrefon- areaelements
- 
      Omitting the hrefattribute is sufficient; thenohrefattribute is unnecessary. Omit it altogether.
- profileon- headelements
- 
      When used for declaring which metaterms are used in the document, unnecessary; omit it altogether, and register the names.
- 
      When used for triggering specific user agent behaviors: use a linkelement instead.
- versionon- htmlelements
- 
      Unnecessary. Omit it altogether. 
- ismapon- inputelements
- 
      Unnecessary. Omit it altogether. All inputelements with atypeattribute in theImage Buttonstate are processed as server-side image maps.
- usemapon- inputelements
- longdescon- iframeelements
- longdescon- imgelements
- 
      Use a regular a element to link to the description, or (in the case of images) use an image map to provide a link from the image to the image’s description. 
- lowsrcon- imgelements
- 
      Use a progressive JPEG image (given in the srcattribute), instead of using two separate images.
- targeton- linkelements
- 
      Unnecessary. Omit it altogether. 
- schemeon- metaelements
- 
      If more than one scheme needs to be declared for a metaelement make the scheme declaration part of the value.
- archiveon- objectelements
- classidon- objectelements
- codeon- objectelements
- codebaseon- objectelements
- codetypeon- objectelements
- 
      Use the dataandtypeattributes to invoke plugins. To set parameters with these names in particular, theparamelement can be used.
- declareon- objectelements
- 
      Repeat the objectelement completely each time the resource is to be reused.
- standbyon- objectelements
- 
      Optimize the linked resource so that it loads quickly or, at least, incrementally. 
- typeon- paramelements
- valuetypeon- paramelements
- 
      Use the nameandvalueattributes without declaring value types.
- languageon- scriptelements (except as noted in the previous section)
- 
      Use the typeattribute instead.
- eventon- scriptelements
- foron- scriptelements
- 
      Use DOM events mechanisms to register event listeners. [DOM] 
- datapagesizeon- tableelements
- 
      Unnecessary. Omit it altogether. 
- summaryon- tableelements
- 
      Use one of the techniques given in the tablesection instead.
- abbron- tdelements
- 
      Use text that begins in an unambiguous and terse manner, and include any more elaborate text after that. The titleattribute can also be useful in including more detailed text, so that the cell’s contents can be made terse. If it’s a heading, useth(which has anabbrattribute).
- axison- tdand- thelements
- scopeon- tdelements
- 
      Use thelements for heading cells.
- datasrcon- a,- applet,- button,- div,- frame,- iframe,- img,- input,- label,- legend,- marquee,- object,- option,- select,- a,- table, and- textareaelements
- datafldon- a,- applet,- button,- div,- fieldset,- frame,- iframe,- img,- input,- label,- legend,- marquee,- object,- param,- select,- a, and- textareaelements
- dataformatason- button,- div,- input,- label,- legend,- marquee,- object,- option,- select,- a, and- tableelements
- 
      Use script and a mechanism such as XMLHttpRequestto populate the page dynamically. [XHR]
- alinkon- bodyelements
- bgcoloron- bodyelements
- bottommarginon- bodyelements
- leftmarginon- bodyelements
- linkon- bodyelements
- marginheighton- bodyelements
- marginwidthon- bodyelements
- rightmarginon- bodyelements
- texton- bodyelements
- topmarginon- bodyelements
- vlinkon- bodyelements
- clearon- brelements
- alignon- captionelements
- alignon- colelements
- charon- colelements
- charoffon- colelements
- valignon- colelements
- widthon- colelements
- alignon- divelements
- compacton- dlelements
- alignon- embedelements
- hspaceon- embedelements
- vspaceon- embedelements
- bordercoloron- frameelements
- alignon- hrelements
- coloron- hrelements
- noshadeon- hrelements
- sizeon- hrelements
- widthon- hrelements
- alignon- h1—- h6elements
- alignon- iframeelements
- allowtransparencyon- iframeelements
- frameborderon- iframeelements
- framespacingon- iframeelements
- hspaceon- iframeelements
- marginheighton- iframeelements
- marginwidthon- iframeelements
- scrollingon- iframeelements
- vspaceon- iframeelements
- alignon- inputelements
- borderon- inputelements
- hspaceon- inputelements
- vspaceon- inputelements
- alignon- imgelements
- borderon- imgelements (except as noted in the previous section)
- hspaceon- imgelements
- vspaceon- imgelements
- alignon- legendelements
- typeon- lielements
- compacton- menuelements
- bgcoloron- marqueeelements
- heighton- marqueeelements
- hspaceon- marqueeelements
- vspaceon- marqueeelements
- widthon- marqueeelements
- alignon- objectelements
- borderon- objectelements
- hspaceon- objectelements
- vspaceon- objectelements
- compacton- olelements
- alignon- pelements
- widthon- preelements
- alignon- tableelements
- bgcoloron- tableelements
- borderon- tableelements
- bordercoloron- tableelements
- cellpaddingon- tableelements
- cellspacingon- tableelements
- frameon- tableelements
- heighton- tableelements
- ruleson- tableelements
- widthon- tableelements
- alignon- tbody,- thead, and- tfootelements
- charon- tbody,- thead, and- tfootelements
- charoffon- tbody,- thead, and- tfootelements
- valignon- tbody,- thead, and- tfootelements
- alignon- tdand- thelements
- bgcoloron- tdand- thelements
- charon- tdand- thelements
- charoffon- tdand- thelements
- heighton- tdand- thelements
- nowrapon- tdand- thelements
- valignon- tdand- thelements
- widthon- tdand- thelements
- alignon- trelements
- bgcoloron- trelements
- charon- trelements
- charoffon- trelements
- heighton- trelements
- valignon- trelements
- compacton- ulelements
- typeon- ulelements
- backgroundon- body,- table,- thead,- tbody,- tfoot,- tr,- td, and- thelements
- 
      Use CSS instead. 
11.3. Requirements for implementations
11.3.1. The applet element
     This feature is in the process of being removed from the Web platform. (This is a long process
    that takes many years.) Using the applet element at this time is highly discouraged. 
The applet element is a Java-specific variant of the embed element.
  The applet element is now obsoleted so that all extension frameworks (Java, .NET,
  Flash, etc) are handled in a consistent manner.
When the element matches any of the following conditions, it represents its contents:
- 
      The element is still in the stack of open elements of an HTML parser or XML parser. 
- 
      The element is not in a document.
- 
      The element’s node document is not fully active. 
- 
      The element’s node document's active sandboxing flag set has its sandboxed plugins browsing context flag set. 
- 
      The element has an ancestor media element. 
- 
      The element has an ancestor objectelement that is not showing its fallback content.
- 
      No Java Language runtime plugin is available. 
- 
      A Java runtime plugin is available but it is disabled. 
- 
      The Should element be blocked a priori by Content Security Policy? algorithm returns "Blocked" when executed on the element. [CSP3] 
Otherwise, the user agent should instantiate a Java Language runtime plugin, and should
  pass the names and values of all the attributes on the element, in the order they were added to
  the element, with the attributes added by the parser being ordered in source order, and then a
  parameter named "PARAM" whose value is null, and then all the names and values of parameters given by param elements that are children of the applet element, in tree order, to the plugin used. If the plugin supports a scriptable interface, the HTMLAppletElement object representing the
  element should expose that interface. The applet element represents the plugin.
 The applet element is unaffected by the CSS display property. The
    Java Language runtime is instantiated even if the element is hidden with a 'display:none' CSS
    style. 
The applet element must implement the HTMLAppletElement interface.
// Note: intentionally not [HTMLConstructor] interface HTMLAppletElement : HTMLElement { attribute DOMString align; attribute DOMString alt; attribute DOMString archive; attribute DOMString code; attribute USVString codeBase; attribute DOMString height; attribute unsigned long hspace; attribute DOMString name; attribute USVString _object; // the underscore is not part of the identifier attribute unsigned long vspace; attribute DOMString width; };
The align, alt, archive, code, height, hspace, name, object, vspace, and width IDL attributes must reflect the respective content attributes of the same name. For the purposes of reflection, the applet element’s object content attribute is defined as containing a URL.
The codeBase IDL attribute must reflect the codebase content attribute, which for the purposes of reflection
  is defined as containing a URL.
11.3.2. The marquee element
    The marquee element is a presentational element that animates content. CSS transitions and
  animations are a more appropriate mechanism. [CSS3-ANIMATIONS] [CSS3-TRANSITIONS]
The task source for tasks mentioned in this section is the DOM manipulation task source.
The marquee element must implement the HTMLMarqueeElement interface.
[HTMLConstructor] interface HTMLMarqueeElement : HTMLElement { [CEReactions] attribute DOMString behavior; [CEReactions] attribute DOMString bgColor; [CEReactions] attribute DOMString direction; [CEReactions] attribute DOMString height; [CEReactions] attribute unsigned long hspace; [CEReactions] attribute long loop; [CEReactions] attribute unsigned long scrollAmount; [CEReactions] attribute unsigned long scrollDelay; [CEReactions] attribute boolean trueSpeed; [CEReactions] attribute unsigned long vspace; [CEReactions] attribute DOMString width; attribute EventHandler onbounce; attribute EventHandler onfinish; attribute EventHandler onstart; void start(); void stop(); };
A marquee element can be turned on or turned off. When it is created, it
  is turned on.
When the start() method is called, the marquee element must be turned on.
When the stop() method is called, the marquee element must be turned off.
When a marquee element is created, the user agent must queue a task to fire an event named start at the element.
The behavior content attribute on marquee elements is an enumerated attribute with the following keywords (all non-conforming):
| Keyword | State | 
|---|---|
| scroll | scroll | 
| slide | slide | 
| alternate | alternate | 
The missing value default is the scroll state.
The direction content attribute on marquee elements is an enumerated attribute with the following keywords (all non-conforming):
| Keyword | State | 
|---|---|
| left | left | 
| right | right | 
| up | up | 
| down | down | 
The missing value default is the left state.
The truespeed content attribute on marquee elements is a boolean attribute.
A marquee element has a marquee scroll interval, which is obtained as follows:
- 
      If the element has a scrolldelayattribute, and parsing its value using the rules for parsing non-negative integers does not return an error, then let delay be the parsed value. Otherwise, let delay be
- 
      If the element does not have a truespeedattribute, and the delay value is less than 60, then let delay be 60 instead.
- 
      The marquee scroll interval is delay, interpreted in milliseconds. 
A marquee element has a marquee scroll distance, which, if the
  element has a scrollamount attribute, and
  parsing its value using the rules for parsing non-negative integers does not return an
  error, is the parsed value interpreted in CSS pixels, and otherwise is 6 CSS pixels.
A marquee element has a marquee loop count, which, if the element has a loop content attribute, and parsing its value
  using the rules for parsing integers does not return an error or a number less than 1, is
  the parsed value, and otherwise is -1.
The loop IDL attribute, on getting,
  must return the element’s marquee loop count; and on setting, if the new value is different
  than the element’s marquee loop count and either greater than zero or equal to -1, must set
  the element’s loop content attribute (adding it if necessary) to the valid integer that represents the new value. (Other values are ignored.)
A marquee element also has a marquee current loop index, which is zero when the
  element is created.
The rendering layer will occasionally increment the marquee current loop index, which must cause the following steps to be run:
- 
      If the marquee loop count is -1, then abort these steps. 
- 
      Increment the marquee current loop index by one. 
- 
      If the marquee current loop index is now equal to or greater than the element’s marquee loop count, turn off the marqueeelement and queue a task to fire an event namedfinishat themarqueeelement.Otherwise, if the behaviorattribute is in the alternate state, then queue a task to fire an event namedbounceat themarqueeelement.Otherwise, queue a task to fire an event named startat themarqueeelement.
The following are the event handlers (and their corresponding event handler event types) that must be supported, as event handler content attributes and event handler IDL attributes, by marquee elements:
| Event handler | Event handler event type | 
|---|---|
| onbounce | bounce | 
| onfinish | finish | 
| onstart | start | 
The behavior, direction, height, hspace, vspace,
  and width IDL attributes must reflect the respective content attributes of the same name.
The bgColor IDL attribute must reflect the bgcolor content attribute.
The scrollAmount IDL attribute must reflect the scrollamount content attribute. The default value is 6.
The scrollDelay IDL attribute must reflect the scrolldelay content attribute. The default value is 85.
The trueSpeed IDL attribute must reflect the truespeed content attribute.
11.3.3. Frames
The frameset element acts as the body element in documents
  that use frames.
The frameset element must implement the HTMLFrameSetElement interface.
[HTMLConstructor] interface HTMLFrameSetElement : HTMLElement { [CEReactions] attribute DOMString cols; [CEReactions] attribute DOMString rows; }; HTMLFrameSetElement implements WindowEventHandlers;
The cols and rows content attributes for the frameset element.
The cols and rows IDL attributes of the frameset element must reflect the respective content attributes of the same name.
The frameset element exposes as event handler content attributes a number of the event handlers of the Window object. It also mirrors their event handler IDL attributes.
The onblur, onerror, onfocus, onload, onresize, and onscroll event handlers of the Window object, exposed on the frameset element, replace the generic event handlers with the same names normally supported by HTML elements.
The frame element defines a nested browsing context similar
  to the iframe element, but rendered within a frameset element.
A frame element is said to be an active frame element when it is in a document.
When a frame element is created as an active frame element, or becomes an active frame element after not having been one, the user agent must create a new browsing context, set the element’s nested browsing context to the
  newly-created browsing context, and then process the frame attributes for the first time. If the element has a name attribute, the browsing context name must be set to the value of this attribute; otherwise, the browsing context name must be set to the empty string.
When a frame element stops being an active frame element, the
  user agent must discard the element’s nested browsing context, and then set the
  element’s nested browsing context to null..
Whenever a frame element with a non-null nested browsing context has its src attribute set, changed, or removed, the user agent must process the frame attributes.
When the user agent is to process the frame attributes, it must run the first
  appropriate steps from the following list:
-  If the element has no srcattribute specified, and the user agent is processing theframe's attributes for the first time
-  Queue a task to fire an event named loadat theframeelement.
- Otherwise
- Run the otherwise steps for iframe or frame elements.
Any navigation required of the user agent in the process the frame attributes algorithm must use the frame element’s node document's browsing context as the source browsing context.
Furthermore, if the active document of the element’s nested browsing context before such a navigation was not completely loaded at the time of the new navigation, then the navigation must be completed with replacement enabled.
Similarly, if the nested browsing context's session history contained
  only one Document when the process the frame attributes algorithm was invoked, and that was the about:blank Document created
  when the nested browsing context was created, then any navigation required of the
  user agent in that algorithm must be completed with replacement enabled.
When a Document in a frame is marked as completely loaded, the user agent must queue a task to fire an event named load at
  the frame element.
The task source for the tasks above is the DOM manipulation task source.
When a frame element’s has a non-null nested browsing context, and its nested browsing context's active document is not ready for post-load tasks, and when anything is delaying the load event of the frame element’s browsing context's active document, and when the frame element’s browsing context is in the delaying load events mode, the frame must delay the load event of its document.
Whenever the <name attribute is set and the frame element’s nested browsing context is non-null, the nested browsing context's name must be changed to the
  new value. If the attribute is removed, the browsing context name must be set to the
  empty string.
The frame element must implement the HTMLFrameElement interface.
[HTMLConstructor] interface HTMLFrameElement : HTMLElement { [CEReactions] attribute DOMString name; [CEReactions] attribute DOMString scrolling; [CEReactions] attribute USVString src; [CEReactions] attribute DOMString frameBorder; [CEReactions] attribute USVString longDesc; [CEReactions] attribute boolean noResize; readonly attribute Document? contentDocument; readonly attribute WindowProxy? contentWindow; [CEReactions, TreatNullAs=EmptyString] attribute DOMString marginHeight; [CEReactions, TreatNullAs=EmptyString] attribute DOMString marginWidth; };
The name, scrolling, and src IDL attributes of the frame element must reflect the respective content attributes of the same name. For the purposes
  of reflection, the frame element’s src content attribute is defined as containing a URL.
The frameBorder IDL attribute of the frame element must reflect the element’s frameborder content attribute.
The longDesc IDL attribute of the frame element must reflect the element’s longdesc content attribute, which
  for the purposes of reflection is defined as containing a URL.
The noResize IDL attribute of the frame element must reflect the element’s noresize content attribute.
The contentDocument IDL attribute, on
  getting, must return the content document.
The contentWindow IDL attribute must
  return the WindowProxy object of the frame element’s nested browsing context, if the element’s nested browsing context is non-null, or
  return null otherwise.
The marginHeight IDL attribute of the frame element must reflect the element’s marginheight content attribute.
The marginWidth IDL attribute of the frame element must reflect the element’s marginwidth content attribute.
11.3.4. Other elements, attributes and APIs
User agents must treat acronym elements in a manner equivalent to abbr elements in terms
  of semantics and for purposes of rendering.
partial interface HTMLAnchorElement { [CEReactions] attribute DOMString coords; [CEReactions] attribute DOMString charset; [CEReactions] attribute DOMString name; [CEReactions] attribute DOMString shape; };
The coords, charset, name, and shape IDL attributes of the th element must reflect the respective content attributes of the same name.
partial interface HTMLAreaElement { [CEReactions] attribute boolean noHref; };
The noHref IDL attribute of the area element must reflect the element’s nohref content attribute.
partial interface HTMLBodyElement { [CEReactions, TreatNullAs=EmptyString] attribute DOMString text; [CEReactions, TreatNullAs=EmptyString] attribute DOMString link; [CEReactions, TreatNullAs=EmptyString] attribute DOMString vLink; [CEReactions, TreatNullAs=EmptyString] attribute DOMString aLink; [CEReactions, TreatNullAs=EmptyString] attribute DOMString bgColor; attribute DOMString background; };
The text IDL attribute of the body element must reflect the element’s text content attribute.
The link IDL attribute of the body element must reflect the element’s link content attribute.
The aLink IDL attribute of the body element must reflect the element’s alink content attribute.
The vLink IDL attribute of the body element must reflect the element’s vlink content attribute.
The bgColor IDL attribute of the body element must reflect the element’s bgcolor content attribute.
The background IDL attribute of the body element must reflect the element’s background content attribute. (The background content is not defined to contain a URL, despite
  rules regarding its handling in the Rendering section above.)
partial interface HTMLBRElement { [CEReactions] attribute DOMString clear; };
The clear IDL attribute of the br element must reflect the content attribute of the same name.
partial interface HTMLTableCaptionElement { [CEReactions] attribute DOMString align; };
The align IDL attribute of the caption element must reflect the content attribute of the same name.
partial interface HTMLTableColElement { [CEReactions] attribute DOMString align; [CEReactions] attribute DOMString ch; [CEReactions] attribute DOMString chOff; [CEReactions] attribute DOMString vAlign; [CEReactions] attribute DOMString width; };
The align and width IDL attributes of the col element must reflect the respective content attributes of the same name.
The ch IDL attribute of the col element must reflect the element’s char content attribute.
The chOff IDL attribute of the col element must reflect the element’s charoff content attribute.
The vAlign IDL attribute of the col element must reflect the element’s valign content attribute.
User agents must treat dir elements in a manner equivalent to ul elements in terms of semantics and for purposes of rendering.
The dir element must implement the HTMLDirectoryElement interface.
[HTMLConstructor] interface HTMLDirectoryElement : HTMLElement { [CEReactions] attribute boolean compact; };
The compact IDL attribute of the dir element must reflect the content attribute of the same name.
partial interface HTMLDivElement { [CEReactions] attribute DOMString align; };
The align IDL attribute of the div element must reflect the content attribute of the same name.
partial interface HTMLDListElement { [CEReactions] attribute boolean compact; };
The compact IDL attribute of the dl element must reflect the content attribute of the same name.
partial interface HTMLEmbedElement { [CEReactions] attribute DOMString align; [CEReactions] attribute DOMString name; };
The name and align IDL attributes of the embed element must reflect the respective content attributes of the same name.
The font element must implement the HTMLFontElement interface.
[HTMLConstructor] interface HTMLFontElement : HTMLElement { [CEReactions, TreatNullAs=EmptyString] attribute DOMString color; [CEReactions] attribute DOMString face; [CEReactions] attribute DOMString size; };
The color, face, and size IDL attributes of the font element must reflect the respective content
  attributes of the same name.
partial interface HTMLHeadingElement { [CEReactions] attribute DOMString align; };
The align IDL attribute of the h1–h6 elements must reflect the content attribute of the same name.
 The profile IDL attribute on head elements (with the HTMLHeadElement interface) is intentionally omitted. Unless so required
    by another applicable specification, implementations would
    therefore not support this attribute. (It is mentioned here as it was defined in a previous
    version of the DOM specifications.) 
partial interface HTMLHRElement { [CEReactions] attribute DOMString align; [CEReactions] attribute DOMString color; [CEReactions] attribute boolean noShade; [CEReactions] attribute DOMString size; [CEReactions] attribute DOMString width; };
The align, color, size,
  and width IDL attributes of the hr element must reflect the respective content attributes of the same name.
The noShade IDL attribute of the hr element must reflect the element’s noshade content attribute.
partial interface HTMLHtmlElement { [CEReactions] attribute DOMString version; };
The version IDL attribute of the html element must reflect the content attribute of the same name.
partial interface HTMLIFrameElement { [CEReactions] attribute DOMString align; [CEReactions] attribute DOMString scrolling; [CEReactions] attribute DOMString frameBorder; [CEReactions] attribute USVString longDesc; [CEReactions, TreatNullAs=EmptyString] attribute DOMString marginHeight; [CEReactions, TreatNullAs=EmptyString] attribute DOMString marginWidth; };
The align and scrolling IDL attributes of the iframe element must reflect the respective content attributes of the same name.
The frameBorder IDL attribute of the iframe element must reflect the element’s frameborder content attribute.
The longDesc IDL attribute of the iframe element must reflect the element’s longdesc content attribute,
  which for the purposes of reflection is defined as containing a URL.
The marginHeight IDL attribute of the iframe element must reflect the element’s marginheight content attribute.
The marginWidth IDL attribute of the iframe element must reflect the element’s marginwidth content attribute.
partial interface HTMLImageElement { [CEReactions] attribute DOMString name; [CEReactions] attribute USVString lowsrc; [CEReactions] attribute DOMString align; [CEReactions] attribute unsigned long hspace; [CEReactions] attribute unsigned long vspace; [CEReactions, TreatNullAs=EmptyString] attribute DOMString border; };
The name, align, border, hspace, and vspace IDL attributes of the img element must reflect the respective content attributes of the same name.
The lowsrc IDL attribute of the img element must reflect the element’s lowsrc content attribute, which for the
  purposes of reflection is defined as containing a URL.
partial interface HTMLInputElement { [CEReactions] attribute DOMString align; [CEReactions] attribute DOMString useMap; };
The align IDL attribute of the input element must reflect the content attribute of the same name.
The useMap IDL attribute of the input element must reflect the element’s usemap content attribute.
partial interface HTMLLegendElement { [CEReactions] attribute DOMString align; };
The align IDL attribute of the legend element must reflect the content attribute of the same name.
partial interface HTMLLIElement { [CEReactions] attribute DOMString type; };
The type IDL attribute of the li element
  must reflect the content attribute of the same name.
partial interface HTMLLinkElement { [CEReactions] attribute DOMString charset; [CEReactions] attribute DOMString target; };
The charset and target IDL attributes of the link element must reflect the respective content attributes of the same name.
User agents must treat listing elements in a manner equivalent to pre elements in
  terms of semantics and for purposes of rendering.
partial interface HTMLMenuElement { [CEReactions] attribute boolean compact; };
The compact IDL attribute of the menu element must reflect the content attribute of the same name.
partial interface HTMLMetaElement { [CEReactions] attribute DOMString scheme; };
User agents may treat the scheme content attribute
  on the meta element as an extension of the element’s name content attribute when
  processing a meta element with a name attribute whose value is one that the user
  agent recognizes as supporting the scheme attribute.
User agents are encouraged to ignore the scheme attribute and instead process the
  value given to the metadata name as if it had been specified for each expected value of the scheme attribute.
meta elements with name attributes having the value "eGMS.subject.keyword", and knows that the scheme attribute is used with this metadata name, then it could take the scheme attribute
    into account, acting as if it was an extension of the name attribute. Thus the
    following two meta elements could be treated as two elements giving values for two
    different metadata names, one consisting of a combination of "eGMS.subject.keyword" and "LGCL",
    and the other consisting of a combination of "eGMS.subject.keyword" and "ORLY": 
<!-- this markup is invalid --> <meta name="eGMS.subject.keyword" scheme="LGCL" content="Abandoned vehicles"> <meta name="eGMS.subject.keyword" scheme="ORLY" content="Mah car: kthxbye">
The suggested processing of this markup, however, would be equivalent to the following:
<meta name="eGMS.subject.keyword" content="Abandoned vehicles"> <meta name="eGMS.subject.keyword" content="Mah car: kthxbye">
The scheme IDL attribute of the meta element must reflect the content attribute of the same name.
partial interface HTMLObjectElement { [CEReactions] attribute DOMString align; [CEReactions] attribute DOMString archive; [CEReactions] attribute DOMString code; [CEReactions] attribute boolean declare; [CEReactions] attribute unsigned long hspace; [CEReactions] attribute DOMString standby; [CEReactions] attribute unsigned long vspace; [CEReactions] attribute DOMString codeBase; [CEReactions] attribute DOMString codeType; [CEReactions, TreatNullAs=EmptyString] attribute DOMString border; };
The align, archive, border, code, declare, hspace, standby, and vspace IDL attributes of the object element must reflect the respective content attributes of the same name.
The codeBase IDL attribute of the object element must reflect the element’s codebase content attribute,
  which for the purposes of reflection is defined as containing a URL.
The codeType IDL attribute of the object element must reflect the element’s codetype content attribute.
partial interface HTMLOListElement { [CEReactions] attribute boolean compact; };
The compact IDL attribute of the ol element must reflect the content attribute of the same name.
partial interface HTMLParagraphElement { [CEReactions] attribute DOMString align; };
The align IDL attribute of the p element must reflect the content attribute of the same name.
partial interface HTMLParamElement { [CEReactions] attribute DOMString type; [CEReactions] attribute DOMString valueType; };
The type IDL attribute of the param element must reflect the content attribute of the same name.
The valueType IDL attribute of the param element must reflect the element’s valuetype content attribute.
User agents must treat plaintext elements in a manner equivalent to pre elements
  in terms of semantics and for purposes of rendering. (The parser has special behavior for this
  element, though.)
partial interface HTMLPreElement { [CEReactions] attribute long width; };
The width IDL attribute of the pre element must reflect the content attribute of the same name.
partial interface HTMLScriptElement { [CEReactions] attribute DOMString event; [CEReactions] attribute DOMString htmlFor; };
The event IDL attribute of the script element must reflect the element’s event content attribute.
The htmlFor IDL attribute of the script element must reflect the element’s for content attribute.
partial interface HTMLTableElement { [CEReactions] attribute DOMString align; [CEReactions] attribute DOMString border; [CEReactions] attribute DOMString frame; [CEReactions] attribute DOMString rules; [CEReactions] attribute DOMString summary; [CEReactions] attribute DOMString width; [CEReactions, TreatNullAs=EmptyString] attribute DOMString bgColor; [CEReactions, TreatNullAs=EmptyString] attribute DOMString cellPadding; [CEReactions, TreatNullAs=EmptyString] attribute DOMString cellSpacing; };
The align, border, frame, summary, rules, and width,
  IDL attributes of the table element must reflect the respective content
  attributes of the same name.
The bgColor IDL attribute of the table element must reflect the element’s bgcolor content attribute.
The cellPadding IDL attribute of the table element must reflect the element’s cellpadding content attribute.
The cellSpacing IDL attribute of the table element must reflect the element’s cellspacing content attribute.
partial interface HTMLTableSectionElement { [CEReactions] attribute DOMString align; [CEReactions] attribute DOMString ch; [CEReactions] attribute DOMString chOff; [CEReactions] attribute DOMString vAlign; };
The align IDL attribute of the tbody, thead, and tfoot elements must reflect the content attribute of the same
  name.
The ch IDL attribute of the tbody, thead, and tfoot elements must reflect the elements' char content attributes.
The chOff IDL attribute of the tbody, thead, and tfoot elements must reflect the elements' charoff content attributes.
The vAlign IDL attribute of the tbody, thead, and tfoot element must reflect the elements' valign content attributes.
partial interface HTMLTableCellElement { [CEReactions] attribute DOMString align; [CEReactions] attribute DOMString axis; [CEReactions] attribute DOMString height; [CEReactions] attribute DOMString width; [CEReactions] attribute DOMString ch; [CEReactions] attribute DOMString chOff; [CEReactions] attribute boolean noWrap; [CEReactions] attribute DOMString vAlign; [CEReactions, TreatNullAs=EmptyString] attribute DOMString bgColor; };
The align, axis, height,
  and width IDL attributes of the td and th elements must reflect the respective content attributes of the same name.
The ch IDL attribute of the td and th elements must reflect the elements' char content attributes.
The chOff IDL attribute of the td and th elements must reflect the elements' charoff content attributes.
The noWrap IDL attribute of the td and th elements must reflect the elements' nowrap content
  attributes.
The vAlign IDL attribute of the td and th elements must reflect the elements' valign content
  attributes.
The bgColor IDL attribute of the td and th elements must reflect the elements' bgcolor content
  attributes.
partial interface HTMLTableRowElement { [CEReactions] attribute DOMString align; [CEReactions] attribute DOMString ch; [CEReactions] attribute DOMString chOff; [CEReactions] attribute DOMString vAlign; [CEReactions, TreatNullAs=EmptyString] attribute DOMString bgColor; };
The align IDL attribute of the tr element must reflect the content attribute of the same name.
The ch IDL attribute of the tr element must reflect the element’s char content attribute.
The chOff IDL attribute of the tr element must reflect the element’s charoff content attribute.
The vAlign IDL attribute of the tr element must reflect the element’s valign content attribute.
The bgColor IDL attribute of the tr element must reflect the element’s bgcolor content attribute.
partial interface HTMLUListElement { [CEReactions] attribute boolean compact; [CEReactions] attribute DOMString type; };
The compact and type IDL attributes of the ul element must reflect the respective content attributes of the
  same name.
User agents must treat xmp elements in a manner equivalent to pre elements in terms of
  semantics and for purposes of rendering. (The parser has special behavior for this element though.)
partial interface Document { [CEReactions, TreatNullAs=EmptyString] attribute DOMString fgColor; [CEReactions, TreatNullAs=EmptyString] attribute DOMString linkColor; [CEReactions, TreatNullAs=EmptyString] attribute DOMString vlinkColor; [CEReactions, TreatNullAs=EmptyString] attribute DOMString alinkColor; [CEReactions, TreatNullAs=EmptyString] attribute DOMString bgColor; [SameObject] readonly attribute HTMLCollection anchors; [SameObject] readonly attribute HTMLCollection applets; void clear(); void captureEvents(); void releaseEvents(); [SameObject] readonly attribute HTMLAllCollection all; };
The attributes of the Document object listed in the first column of the following table must reflect the content attribute on the body element with the name given in the
  corresponding cell in the second column on the same row, if the body element is a body element (as opposed to a frameset element). When there is no body element or if it is a frameset element, the attributes must instead return the empty string on getting and do
  nothing on setting.
| IDL attribute | Content attribute | 
|---|---|
| fgColor | text | 
| linkColor | link | 
| vlinkColor | vlink | 
| alinkColor | alink | 
| bgColor | bgcolor | 
The anchors attribute must return an HTMLCollection rooted at the Document node, whose filter matches only a elements with name attributes.
The applets attribute must return an HTMLCollection rooted at the Document node, whose filter matches only applet elements.
The clear(), captureEvents(), and releaseEvents() methods must do nothing.
The all attribute must return an HTMLAllCollection rooted at the Document node, whose filter matches all elements.
The object returned for all has several unusual behaviors:
- 
      The user agent must act as if the ToBoolean abstract operator in JavaScript converts the object returned for allto the false value.
- 
      The user agent must act as if the Abstract Equality Comparison algorithm, when given the object returned for all, returns true when compared to theundefinedandnullvalues. (Comparisons using the Strict Equality Comparison algorithm, and Abstract Equality comparisons to other values such as strings or objects, are unaffected.)
- 
      The user agent must act such that the typeofoperator in JavaScript returns the stringundefinedwhen applied to the object returned forall.
 These requirements are a willful violation of the JavaScript specification current at the
    time of writing. The JavaScript specification requires that ToBoolean return true for all
    objects to the true value, and does not have provisions for objects acting as if they were undefined for the purposes of certain operators. This violation is motivated by a
    desire for compatibility with two classes of legacy content: one that uses the presence of document.all as a way to detect legacy user agents, and one that only supports
    those legacy user agents and uses the document.all object without testing for
    its presence first. [ECMA-262] 
partial interface Window { void captureEvents(); void releaseEvents(); [Replaceable, SameObject] readonly attribute External external; };
The captureEvents() and releaseEvents() methods must do nothing.
The external attribute of the Window interface
  must return an instance of the External interface:
[NoInterfaceObject] interface External { void AddSearchProvider(); void IsSearchProviderInstalled(); };
The AddSearchProvider() and IsSearchProviderInstalled() methods must do nothing.