Authors may use the ARIA role and aria-* attributes on HTML elements, in accordance with the requirements described in the ARIA specifications, except where these conflict with the strong native semantics described below. These exceptions are intended to prevent authors from making assistive technology products report nonsensical states that do not represent the actual state of the document. [ARIA]
The following table defines the strong native semantics and corresponding default implicit ARIA semantics that apply to HTML elements. Each language feature (element or attribute) in a cell in the first column implies the ARIA semantics (role, states, and/or properties) given in the cell in the second column of the same row.
| Language feature | Strong native semantics and default implied ARIA semantics | 
|---|---|
| areaelement that creates a hyperlink | linkrole | 
| baseelement | No role | 
| datalistelement | listboxrole, with thearia-multiselectableproperty set to "false" | 
| detailselement | aria-expandedstate set to "true" if the element'sopenattribute is present, and set to "false" otherwise | 
| headelement | No role | 
| hgroupelement | headingrole, with thearia-levelproperty set to the element's outline depth | 
| hrelement | separatorrole | 
| htmlelement | No role | 
| imgelement whosealtattribute's value is empty | presentationrole | 
| inputelement with atypeattribute in the Checkbox state | aria-checkedstate set to "mixed" if the element'sindeterminateIDL attribute is true, or "true" if the element's checkedness is true, or "false" otherwise | 
| inputelement with atypeattribute in the Color state | No role | 
| inputelement with atypeattribute in the Date state | No role, with the aria-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement with atypeattribute in the Date and Time state | No role, with the aria-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement with atypeattribute in the Local Date and Time state | No role, with the aria-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement with atypeattribute in the E-mail state with no suggestions source element | textboxrole, with thearia-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement with atypeattribute in the File Upload state | No role | 
| inputelement with atypeattribute in the  state | No role | 
| inputelement with atypeattribute in the Month state | No role, with the aria-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement with atypeattribute in the Number state | spinbuttonrole, with thearia-readonlystate set to "true" if the element has areadonlyattribute, thearia-valuemaxproperty set to the element's maximum, thearia-valueminproperty set to the element's minimum, and, if the result of applying the rules for parsing floating point number values to the element's value is a number, with thearia-valuenowproperty set to that number | 
| inputelement with atypeattribute in the Password state | textboxrole, with thearia-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement with atypeattribute in the Radio Button state | aria-checkedstate set to "true" if the element's checkedness is true, or "false" otherwise | 
| inputelement with atypeattribute in the Range state | sliderrole, with thearia-valuemaxproperty set to the element's maximum, thearia-valueminproperty set to the element's minimum, and thearia-valuenowproperty set to the result of applying the rules for parsing floating point number values to the element's value, if that results in a number, or the default value otherwise | 
| inputelement with atypeattribute in the Reset Button state | buttonrole | 
| inputelement with atypeattribute in the Search state with no suggestions source element | textboxrole, with thearia-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement with atypeattribute in the Submit Button state | buttonrole | 
| inputelement with atypeattribute in the Telephone state with no suggestions source element | textboxrole, with thearia-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement with atypeattribute in the Text state with no suggestions source element | textboxrole, with thearia-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement with atypeattribute in the Text, Search, Telephone, URL, or E-mail states with a suggestions source element | comboboxrole, with thearia-ownsproperty set to the same value as thelistattribute, and thearia-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement with atypeattribute in the Time state | No role, with the aria-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement with atypeattribute in the URL state with no suggestions source element | textboxrole, with thearia-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement with atypeattribute in the Week state | No role, with the aria-readonlystate set to "true" if the element has areadonlyattribute | 
| inputelement that is required | The aria-requiredstate set to "true" | 
| keygenelement | No role | 
| labelelement | No role | 
| linkelement that creates a hyperlink | linkrole | 
| menuelement with atypeattribute in the context menu state | No role | 
| menuelement with atypeattribute in the list state | menurole | 
| menuelement with atypeattribute in the toolbar state | toolbarrole | 
| metaelement | No role | 
| meterelement | No role | 
| navelement | navigationrole | 
| noscriptelement | No role | 
| optgroupelement | No role | 
| optionelement that is in a list of options or that represents a suggestion in adatalistelement | optionrole, with thearia-selectedstate set to "true" if the element's selectedness is true, or "false" otherwise. | 
| paramelement | No role | 
| progresselement | progressbarrole, with, if the progress bar is determinate, thearia-valuemaxproperty set to the maximum value of the progress bar, thearia-valueminproperty set to zero, and thearia-valuenowproperty set to the current value of the progress bar | 
| scriptelement | No role | 
| selectelement with amultipleattribute | listboxrole, with thearia-multiselectableproperty set to "true" | 
| selectelement with nomultipleattribute | listboxrole, with thearia-multiselectableproperty set to "false" | 
| selectelement with arequiredattribute | The aria-requiredstate set to "true" | 
| sourceelement | No role | 
| styleelement | No role | 
| summaryelement | No role | 
| textareaelement | textboxrole, with thearia-multilineproperty set to "true", and thearia-readonlystate set to "true" if the element has areadonlyattribute | 
| textareaelement with arequiredattribute | The aria-requiredstate set to "true" | 
| titleelement | No role | 
| An element that defines a command, whose Type facet is "checkbox", and that is a descendant of a menuelement whosetypeattribute in the list state | menuitemcheckboxrole, with thearia-checkedstate set to "true" if the command's Checked State facet is true, and "false" otherwise | 
| An element that defines a command, whose Type facet is "command", and that is a descendant of a menuelement whosetypeattribute in the list state | menuitemrole | 
| An element that defines a command, whose Type facet is "radio", and that is a descendant of a menuelement whosetypeattribute in the list state | menuitemradiorole, with thearia-checkedstate set to "true" if the command's Checked State facet is true, and "false" otherwise | 
| Element that is disabled | The aria-disabledstate set to "true" | 
| Element with a attribute | The aria-hiddenstate set to "true" | 
| Element that is a candidate for constraint validation but that does not satisfy its constraints | The aria-invalidstate set to "true" | 
Some HTML elements have native semantics that can be overridden. The following table lists these elements and their default implicit ARIA semantics, along with the restrictions that apply to those elements. Each language feature (element or attribute) in a cell in the first column implies, unless otherwise overridden, the ARIA semantic (role, state, or property) given in the cell in the second column of the same row, but this semantic may be overridden under the conditions listed in the cell in the third column of that row. In addition, any element may be given the presentation role, regardless of the restrictions below.
| Language feature | Default implied ARIA semantic | Restrictions | 
|---|---|---|
| aelement that creates a hyperlink | linkrole | Role must be either link,button,checkbox,menuitem,menuitemcheckbox,menuitemradio,tab, ortreeitem | 
| addresselement | No role | If specified, role must be contentinfo | 
| articleelement | articlerole | Role must be either article,document,application, ormain | 
| asideelement | noterole | Role must be either note,complementary, orsearch | 
| audioelement | No role | If specified, role must be application | 
| buttonelement | buttonrole | Role must be either button,link,menuitem,menuitemcheckbox,menuitemradio,radio | 
| detailselement | grouprole | Role must be a role that supports aria-expanded | 
| embedelement | No role | If specified, role must be either application,document, orimg | 
| footerelement | No role | If specified, role must be contentinfo | 
| h1element that does not have anhgroupancestor | headingrole, with thearia-levelproperty set to the element's outline depth | Role must be either link,menuitem,menuitemcheckbox,menuitemradio,tab, ortreeitem | 
| h2element that does not have anhgroupancestor | headingrole, with thearia-levelproperty set to the element's outline depth | Role must be either link,menuitem,menuitemcheckbox,menuitemradio,tab, ortreeitem | 
| h3element that does not have anhgroupancestor | headingrole, with thearia-levelproperty set to the element's outline depth | Role must be either link,menuitem,menuitemcheckbox,menuitemradio,tab, ortreeitem | 
| h4element that does not have anhgroupancestor | headingrole, with thearia-levelproperty set to the element's outline depth | Role must be either link,menuitem,menuitemcheckbox,menuitemradio,tab, ortreeitem | 
| h5element that does not have anhgroupancestor | headingrole, with thearia-levelproperty set to the element's outline depth | Role must be either link,menuitem,menuitemcheckbox,menuitemradio,tab, ortreeitem | 
| h6element that does not have anhgroupancestor | headingrole, with thearia-levelproperty set to the element's outline depth | Role must be either link,menuitem,menuitemcheckbox,menuitemradio,tab, ortreeitem | 
| headerelement | No role | If specified, role must be banner | 
| iframeelement | No role | If specified, role must be either application,document, orimg | 
| imgelement whosealtattribute's value is absent | imgrole | No restrictions | 
| imgelement whosealtattribute's value is present and not empty | imgrole | No restrictions | 
| inputelement with atypeattribute in the Button state | buttonrole | Role must be either button,link,menuitem,menuitemcheckbox,menuitemradio,radio | 
| inputelement with atypeattribute in the Checkbox state | checkboxrole | Role must be either checkboxormenuitemcheckbox | 
| inputelement with atypeattribute in the Image Button state | buttonrole | Role must be either button,link,menuitem,menuitemcheckbox,menuitemradio,radio | 
| inputelement with atypeattribute in the Radio Button state | radiorole | Role must be either radioormenuitemradio | 
| lielement whose parent is anolorulelement | listitemrole | Role must be either listitem,menuitemcheckbox,menuitemradio,option,tab, ortreeitem | 
| objectelement | No role | If specified, role must be either application,document, orimg | 
| olelement | listrole | Role must be either directory,list,listbox,menu,menubar,tablist,toolbar,tree | 
| outputelement | statusrole | No restrictions | 
| sectionelement | regionrole | Role must be either alert,alertdialog,application,contentinfo,dialog,document,log,main,marquee,region,search, orstatus | 
| ulelement | listrole | Role must be either directory,list,listbox,menu,menubar,tablist,toolbar,tree | 
| videoelement | No role | If specified, role must be application | 
| The body element | documentrole | Role must be either documentorapplication | 
The entry "no role", when used as a strong native semantic, means that no role other than presentation can be used. When used as a default implied ARIA semantic, it means the user agent has no default mapping to ARIA roles. (However, it probably will have its own mappings to the accessibility layer.)
These features can be used to make accessibility tools render content to their users in more useful ways. For example, ASCII art, which is really an image, appears to be text, and in the absence of appropriate annotations would end up being rendered by screen readers as a very painful reading of lots of punctuation. Using the features described in this section, one can instead make the ATs skip the ASCII art and just read the caption:
<figure role="img" aria-labelledby="fish-caption"> 
 <pre>
 o           .'`/
     '      /  (
   O    .-'` ` `'-._      .')
      _/ (o)        '.  .' /
      )       )))     ><  <
      `\  |_\      _.'  '. \
        '-._  _ .-'       '.)
    jgs     `\__\
 </pre>
 <figcaption id="fish-caption">
  Joan G. Stark, "<cite>fish</cite>".
  October 1997. ASCII on electrons. 28×8.
 </figcaption> 
</figure>