CSS Object Model (CSSOM)

The CSS Object Model is a set of APIs allowing the manipulation of CSS from JavaScript. It is much like the DOM, but for the CSS rather than the HTML. It allows users to read and modify CSS style dynamically.

Reference

Several other interfaces are also extended by the CSSOM-related specifications: Document, Window, Element, HTMLElement, HTMLImageElement, Range, MouseEvent, and SVGElement.

CSS Typed Object Model

Experimental

This is an experimental technology
Check the Browser compatibility table carefully before using this in production.

Obsolete CSSOM interfaces

Deprecated

This feature is no longer recommended. Though some browsers might still support it, it may have already been removed from the relevant web standards, may be in the process of being dropped, or may only be kept for compatibility purposes. Avoid using it, and update existing code if possible; see the compatibility table at the bottom of this page to guide your decision. Be aware that this feature may cease to work at any time.

Tutorials

Specifications

Specification Status Comment
CSS Typed OM Level 1 Working Draft
CSS Painting API Level 1 Working Draft Extended the CSS interface with the paintWorklet static property.
CSS Object Model (CSSOM) View Module Working Draft Defined the Screen and MediaQueryList interfaces and the MediaQueryListEvent event and MediaQueryList event listener.
CSS Object Model (CSSOM) Working Draft Extended the CSS interface and provides the base for the modern CSSOM specification.
Screen Orientation API Working Draft
CSS Fonts Module Level 3 Recommendation
CSS Animations Level 1 Working Draft
CSS Transitions Working Draft
CSS Custom Properties for Cascading Variables Module Level 1 Candidate Recommendation
CSS Conditional Rules Module Level 3 Candidate Recommendation Defined the CSS interface.
CSS Device Adaptation Working Draft
CSS Counter Styles Level 3 Candidate Recommendation
Document Object Model (DOM) Level 2 Style Specification Obsolete Initial definition.

Browser compatibility

All these features have been added little by little over the years to the different browsers: it was a quite complex process that can't be summarized in a simple table. Please refer to the specific interfaces for its availability.

See also