CSS Scoped Custom Properties: Understanding Scope and Inheritance
When defining CSS custom properties, understanding their scope is crucial for achieving desired effects. Custom properties declared within an element are scoped to that element and its descendants. However, this scoping can sometimes lead to unexpected behavior, as illustrated in this question.
The issue stems from the fact that in the provided code, the custom property --scale is defined at the root level and then overridden within child elements. This overriding behavior is not expected when using scoped custom properties.
To demonstrate this issue, let's analyze the CSS:
:root { --size-1: calc(1 * var(--scale, 1) * 1rem); --size-2: calc(2 * var(--scale, 1) * 1rem); --size-3: calc(3 * var(--scale, 1) * 1rem); } .scale-1x { --scale: 1; } .scale-2x { --scale: 2; } .scale-3x { --scale: 3; }
Here, the --size-* properties depend on the value of --scale. However, when defining --scale inside the .scale-1x, .scale-2x, and .scale-3x classes, it overrides the value defined in :root.
The expected behavior would be for the --scale property to be evaluated at each element where it is defined, resulting in different font sizes for each list. However, this does not occur because the custom property is already evaluated at the root level.
To address this issue and achieve the desired effect, consider using scoped custom properties more consistently. For example, define --size-1, --size-2, and --size-3 within each .scale-* class, ensuring they are scoped to that element only. This will allow for independent scaling of each list based on the value of --scale defined within its respective class.
The above is the detailed content of How Do CSS Scoped Custom Properties Handle Inheritance and Overriding?. For more information, please follow other related articles on the PHP Chinese website!

Feedbin is the RSS reader I'm using at the moment. I was reading one of Harry's blog posts on it the other day, and I noticed a nice little interactive touch

This week, Chris Ferdinandi examined a clever JavaScript snippet, one that's written creatively with new syntax features, but is perhaps less readable and

Creating CSS-based animations and transitions can be a challenge. They can be complex and time-consuming. Need to move forward with a project with little time

In this week's news, Google defines guidelines for favicons, a new a11y testing tool from The Paciello Group, and changes to how the W3C plans to engage the community, plus more.

Here's a container with some child elements:

Flyout menus! The second you need to implement a menu that uses a hover event to display more menu items, you're in tricky territory. For one, they should

"The power of the Web is in its universality. Access by everyone regardless of disability is an essential aspect."- Tim Berners-Lee

In this week's roundup: datepickers are giving keyboard users headaches, a new web component compiler that helps fight FOUC, we finally get our hands on styling list item markers, and four steps to getting webmentions on your site.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft