hidden attributeAll HTML elements may have the  content attribute set. The  attribute is a boolean
  attribute. When specified on an element, it indicates that
  the element is not yet, or is no longer, relevant. 
In the following skeletal example, the attribute is used to hide the Web game's main screen until the user logs in:
  <h1>The Example Game</h1>
  <section id="login">
   <h2>Login</h2>
   <form>
    ...
    <!-- calls login() once the user's credentials have been checked -->
   </form>
   <script>
    function login() {
      // switch screens
      document.getElementById('login').hidden = true;
      document.getElementById('game').hidden = false;
    }
   </script>
  </section>
  <section id="game" hidden>
   ...
  </section>
  The  attribute must not be
  used to hide content that could legitimately be shown in another
  presentation. For example, it is incorrect to use  to hide panels in a tabbed dialog,
  because the tabbed interface is merely a kind of overflow
  presentation — one could equally well just show all the form
  controls in one big page with a scrollbar. It is similarly incorrect
  to use this attribute to hide content just from one presentation
  — if something is marked , it is hidden from all
  presentations, including, for instance, screen readers.
Elements that are not 
  should not link to or refer to elements that are .
For example, it would be incorrect to use the href attribute to link to a
   section marked with the 
   attribute. If the content is not applicable or relevant, then there
   is no reason to link to it.
It would similarly be incorrect to use the ARIA aria-describedby attribute to
   refer to descriptions that are themselves . Hiding a section means that it
   is not applicable or relevant to anyone at the current time, so
   clearly it cannot be a valid description of content the user can
   interact with.
Elements in a section hidden by the  attribute are still active,
  e.g. scripts and form controls in such sections still execute
  and submit respectively. Only their presentation to the user
  changes.
click()Acts as if the element was clicked.
tabindex attributeThe tabindex
  content attribute specifies whether the element is focusable,
  whether it can be reached using sequential focus navigation, and the
  relative order of the element for the purposes of sequential focus
  navigation. The name "tab index" comes from the common use of the
  "tab" key to navigate through the focusable elements. The term
  "tabbing" refers to moving forward through the focusable elements
  that can be reached using sequential focus navigation.
The tabindex attribute, if
  specified, must have a value that is a valid
  integer.
activeElementReturns the currently focused element.
hasFocus()Returns true if the document has focus; otherwise, returns false.
focus()Focuses the window. Use of this method is discouraged. Allow the user to control window focus instead.
blur()Unfocuses the window. Use of this method is discouraged. Allow the user to control window focus instead.
focus()Focuses the element.
blur()Unfocuses the element. Use of this method is discouraged. Focus another element instead.
Do not use this method to hide the focus ring if you find the focus ring unsightly. Instead, use a CSS rule to override the 'outline' property.
For example, to hide the outline from links, you could use:
:link:focus, :visited:focus { outline: none; }
    This section is non-normative.
Each element that can be activated or focused can be assigned a
  single key combination to activate it, using the accesskey attribute.
The exact shortcut is determined by the user agent, based on
  information about the user's keyboard, what keyboard shortcuts
  already exist on the platform, and what other shortcuts have been
  specified on the page, using the information provided in the accesskey attribute as a guide.
In order to ensure that a relevant keyboard shortcut is available
  on a wide variety of input devices, the author can provide a number
  of alternatives in the accesskey
  attribute.
Each alternative consists of a single character, such as a letter or digit.
User agents can provide users with a list of the keyboard
  shortcuts, but authors are encouraged to do so also. The accessKeyLabel IDL attribute
  returns a string representing the actual key combination assigned by
  the user agent.
accesskey attributeAll HTML elements may have the accesskey content attribute set. The
  accesskey attribute's value is
  used by the user agent as a guide for creating a keyboard shortcut
  that activates or focuses the element.
If specified, the value must be an ordered set of unique space-separated tokens that are case-sensitive, each of which must be exactly one Unicode code point in length.
In the following example, a variety of links are given with access keys so that keyboard users familiar with the site can more quickly navigate to the relevant pages:
<nav> <p> <a title="Consortium Activities" accesskey="A" href="/Consortium/activities">Activities</a> | <a title="Technical Reports and Recommendations" accesskey="T" href="/TR/">Technical Reports</a> | <a title="Alphabetical Site Index" accesskey="S" href="/Consortium/siteindex">Site Index</a> | <a title="About This Site" accesskey="B" href="/Consortium/">About Consortium</a> | <a title="Contact Consortium" accesskey="C" href="/Consortium/contact">Contact</a> </p> </nav>
In the following example, the search field is given two possible access keys, "s" and "0" (in that order). A user agent on a device with a full keyboard might pick Ctrl+Alt+S as the shortcut key, while a user agent on a small device with just a numeric keypad might pick just the plain unadorned key 0:
<form action="/search"> <label>Search: <input type="search" name="q" accesskey="s 0"></label> <input type="submit"> </form>
In the following example, a button has possible access keys described. A script then tries to update the button's label to advertise the key combination the user agent selected.
<input type=submit accesskey="N @ 1" value="Compose">
...
<script>
 function labelButton(button) {
   if (button.accessKeyLabel)
     button.value += ' (' + button.accessKeyLabel + ')';
 }
 var inputs = document.getElementsByTagName('input');
 for (var i = 0; i < inputs.length; i += 1) {
   if (inputs[i].type == "submit")
     labelButton(inputs[i]);
 }
</script>
   On one user agent, the button's label might become "Compose (⌘N)". On another, it might become "Compose (Alt+⇧+1)". If the user agent doesn't assign a key, it will be just "Compose". The exact string depends on what the assigned access key is, and on how the user agent represents that key combination.
contenteditable attributeThe contenteditable
  attribute is an enumerated attribute whose keywords are
  the empty string, true, and false. The empty string and the true keyword map to the true state. The false keyword maps to the false state. In
  addition, there is a third state, the inherit state, which is
  the missing value default (and the invalid value
  default).
The true state indicates that the element is editable. The inherit state indicates that the element is editable if its parent is. The false state indicates that the element is not editable.
contentEditable [ = value ]Returns "true", "false", or "inherit", based
    on the state of the contenteditable attribute.
Can be set, to change that state.
Throws a SYNTAX_ERR exception if the new value
    isn't one of those strings.
isContentEditableReturns true if the element is editable; otherwise, returns false.
designMode [ = value ]Returns "on" if the document is editable,
    and "off" if it isn't.
Can be set, to change the document's current state.
The spellcheck
  attribute is an enumerated attribute whose keywords are
  the empty string, true and false. The empty string and the true keyword map to the true state. The false keyword maps to the false state. In
  addition, there is a third state, the default state, which is
  the missing value default (and the invalid value
  default).
The true state indicates that the element is to have its
  spelling and grammar checked. The default state indicates
  that the element is to act according to a default behavior, possibly
  based on the parent element's own spellcheck state. The false
  state indicates that the element is not to be checked.
spellcheck [ = value ]Returns true if the element is to have its spelling and grammar checked; otherwise, returns false.
Can be set, to override the default and set the spellcheck content attribute.
This specification does not define the user interface for spelling and grammar checkers. A user agent could offer on-demand checking, could perform continuous checking while the checking is enabled, or could use other interfaces.