Home  >  Article  >  Web Front-end  >  Can JavaScript Access Custom CSS Properties with Invalid Names?

Can JavaScript Access Custom CSS Properties with Invalid Names?

Barbara Streisand
Barbara StreisandOriginal
2024-10-24 07:07:02137browse

Can JavaScript Access Custom CSS Properties with Invalid Names?

Accessing Invalid Custom CSS Properties from JavaScript

It is possible to create custom CSS properties using the - prefix. However, can these custom properties be accessed from JavaScript?

The answer is unfortunately no, at least in major browsers like Chrome and Firefox. Custom CSS properties with invalid names are simply ignored by the CSS parser. For instance, consider the following CSS:

<code class="css">div {
    -my-foo: 42;
}</code>

Even if this CSS is applied to a div, attempting to access the -my-foo property using JavaScript will return nothing. The CSSStyleDeclaration object will only contain valid properties, such as width or height.

This behavior is in accordance with the CSSStyleDeclaration specifications. The specs state that the object should only include "specified properties," which implies that custom properties are not recognized. However, some implementations may support accessing custom properties, but this is not guaranteed.

If accessing custom CSS properties is crucial for your application, you can bypass the limitations of JavaScript by parsing the raw CSS text. This can be done using the innerText property of the style element:

<code class="js">document.getElementsByTagName("style")[0].innerText</code>

While this approach works, it is not as straightforward as accessing the properties directly from the CSSStyleDeclaration object. Moreover, it requires additional parsing and manipulation of the CSS text.

The above is the detailed content of Can JavaScript Access Custom CSS Properties with Invalid Names?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn