CSS: supports() static method
{{APIRef("CSSOM")}}
The CSS.supports() static method returns a boolean value
indicating if the browser supports a given CSS feature, or not.
Syntax
CSS.supports(propertyName, value)
CSS.supports(supportCondition)
Parameters
There are two distinct sets of parameters. The first one allows to test the support of a pair property-value:
propertyName- : A string containing the name of the CSS property to check.
value- : A string containing the value of the CSS property to check.
The second syntax takes one parameter matching the condition of
{{cssxref("@supports")}} :
supportCondition- : A string containing the condition to check.
Return value
true if the browser supports the rule, otherwise false.
Examples
In the following examples, result is a boolean value indicating if the browser supports the given CSS feature.
result = CSS.supports("text-decoration-style", "blink");
result = CSS.supports("display: flex");
result = CSS.supports("(--foo: red)");
result = CSS.supports("selector(:has(a))");
result = CSS.supports(
"(transform-style: preserve) or (-moz-transform-style: preserve) or (-webkit-transform-style: preserve)",
);
For more examples and syntax features, see the {{cssxref("@supports")}} at-rule.
Specifications
{{Specifications}}
Browser compatibility
{{Compat}}
See also
- The
{{cssxref("@supports")}}at-rule that allows for the same functionality but in a declarative way. - The
{{domxref("CSSSupportsRule")}}CSSOM class allowing to manipulate{{cssxref("@supports")}}at-rules.