---
id: dom-elements
title: DOM Elements
layout: docs
category: Reference
permalink: docs/dom-elements.html
redirect_from:
- "docs/tags-and-attributes.html"
- "docs/dom-differences.html"
- "docs/special-non-dom-attributes.html"
- "docs/class-name-manipulation.html"
- "tips/inline-styles.html"
- "tips/style-props-value-px.html"
- "tips/dangerously-set-inner-html.html"
---
React implements a browser-independent DOM system for performance and cross-browser compatibility. We took the opportunity to clean up a few rough edges in browser DOM implementations.
In React, all DOM properties and attributes (including event handlers) should be camelCased. For example, the HTML attribute `tabindex` corresponds to the attribute `tabIndex` in React. The exception is `aria-*` and `data-*` attributes, which should be lowercased. For example, you can keep `aria-label` as `aria-label`.
## Differences In Attributes
There are a number of attributes that work differently between React and HTML:
### checked
The `checked` attribute is supported by `` components of type `checkbox` or `radio`. You can use it to set whether the component is checked. This is useful for building controlled components. `defaultChecked` is the uncontrolled equivalent, which sets whether the component is checked when it is first mounted.
### className
To specify a CSS class, use the `className` attribute. This applies to all regular DOM and SVG elements like `