Can JavaScript Access Custom CSS Properties with Invalid Names?

Barbara Streisand
Release: 2024-10-24 07:07:02
Original
146 people have browsed it

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>
Copy after login

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>
Copy after login

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!

source:php
Statement of this Website
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
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!