search
HomeWeb Front-endCSS TutorialHow to Get All Custom Properties on a Page in JavaScript

How to Get All Custom Properties on a Page in JavaScript

This article describes how to use JavaScript to get CSS custom property values ​​and build an automatically generated palette example. We know that you can use getComputedStyle and getPropertyValue to access a single custom property, but if there are multiple properties, you will need to write a lot of duplicate code. This article will show how to automate this process.

Suppose we have declared multiple custom properties on the HTML element:

 html {
  --color-accent: #00eb9b;
  --color-accent-secondary: #9db4ff;
  --color-accent-tertiary: #f2c0ea;
  --color-text: #292929;
  --color-divider: #d7d7d7;
}

We can automatically get all custom properties and generate a palette through the following steps:

  1. Get all stylesheets: Use document.styleSheets to get all stylesheets (inner and outer) on the page.

  2. Filter third-party stylesheets: For security reasons, only stylesheets on the current domain are processed. We use the isSameDomain function to filter out third-party stylesheets:

     const isSameDomain = (styleSheet) => {
      if (!styleSheet.href) return true;
      return styleSheet.href.indexOf(window.location.origin) === 0;
    };
  3. Get all style rules: Use reduce and concat methods to merge all style rules into an array.

  4. Filter non-base style rules: only rules of type CSSStyleRule are retained, and other types of rules (such as CSSMediaRule ). Use the isStyleRule function to filter:

     const isStyleRule = (rule) => rule.type === 1;
  5. Get the names and values ​​of all attributes: Iterate through the style attribute ( CSSStyleDeclaration object) of each style rule, and use map method to get the names and values ​​of all attributes.

  6. Filter non-custom attributes: Only custom attributes starting with -- are preserved. Use filter method to filter.

  7. Generate HTML: Use the reduce method to generate HTML code based on the obtained custom attributes and values, and use it to display the color palette. We use<div> Elements are used as color samples and set colors using inline styles. External CSS uses <code>var(--color) to set the background color.

    The final code will be similar to the following structure (see the original text for specific implementation details):

     const getCSSCustomPropIndex = () => [...document.styleSheets]
      .filter(isSameDomain)
      .reduce((finalArr, sheet) => finalArr.concat(
        [...sheet.cssRules]
          .filter(isStyleRule)
          .reduce((propValArr, rule) => {
            const props = [...rule.style]
              .map((propName) => [propName.trim(), rule.style.getPropertyValue(propName).trim()])
              .filter(([propName]) => propName.indexOf("--") === 0);
            return [...propValArr, ...props];
          }, [])
      ), []);
    
    const cssCustomPropIndex = getCSSCustomPropIndex();
    document.querySelector(".colors").innerHTML = cssCustomPropIndex.reduce(
      (str, [prop, val]) => `${str}<div class="color__swatch" style="--color: ${val};"></div> `, "");

    This method automatically generates a color palette that displays all CSS custom properties without having to write a lot of code manually. In the future, you can use the CSSStyleRule.styleMap property in CSS Typed Object Model Level 1 draft to simplify the code.

The above is the detailed content of How to Get All Custom Properties on a Page in JavaScript. 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
The Slideout FooterThe Slideout FooterApr 09, 2025 am 11:50 AM

A fascinating new site called The Markup just launched. Tagline: Big Tech Is Watching You. We’re Watching Big Tech. Great work from Upstatement. The

Pages for LikesPages for LikesApr 09, 2025 am 11:47 AM

I posted about parsing an RSS feed in JavaScript the other day. I also posted about my RSS setup talking about how Feedbin is at the heart of it.

Recreating the CodePen Gutenberg Embed Block for Sanity.ioRecreating the CodePen Gutenberg Embed Block for Sanity.ioApr 09, 2025 am 11:43 AM

Learn how to create a custom CodePen block with a preview for Sanity Studio, inspired by Chris Coyier’s implementation for Wordpress’ Gutenberg editor.

How to Make a Line Chart With CSSHow to Make a Line Chart With CSSApr 09, 2025 am 11:36 AM

Line,  bar, and pie charts are the bread and butter of dashboards and are the basic components of any data visualization toolkit. Sure, you can use SVG

Programming Sass to Create Accessible Color CombinationsProgramming Sass to Create Accessible Color CombinationsApr 09, 2025 am 11:30 AM

We are always looking to make the web more accessible. Color contrast is just math, so Sass can help cover edge cases that designers might have missed.

How We Created a Static Site That Generates Tartan Patterns in SVGHow We Created a Static Site That Generates Tartan Patterns in SVGApr 09, 2025 am 11:29 AM

Tartan is a patterned cloth that’s typically associated with Scotland, particularly their fashionable kilts. On tartanify.com, we gathered over 5,000 tartan

A Follow-Up to PHP TemplatingA Follow-Up to PHP TemplatingApr 09, 2025 am 11:14 AM

Not long ago, I posted about PHP templating in just PHP (which is basically HEREDOC syntax). I'm literally using that technique for some super basic

Creating a Modal Image Gallery With Bootstrap ComponentsCreating a Modal Image Gallery With Bootstrap ComponentsApr 09, 2025 am 11:10 AM

Have you ever clicked on an image on a webpage that opens up a larger version of the image with navigation to view other photos?

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

SecLists

SecLists

SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use