- From: Romain Menke via GitHub <sysbot+gh@w3.org>
- Date: Tue, 26 Apr 2022 07:44:22 +0000
- To: public-css-archive@w3.org
romainmenke has just created a new issue for https://github.com/w3c/csswg-drafts:
== [css-cascade-6] Is it possible to create a scoping boundary over sibling elements? ==
https://www.w3.org/TR/2021/WD-css-cascade-6-20211221/#scoped-styles
> [Scoping limits](https://www.w3.org/TR/2021/WD-css-cascade-6-20211221/#scoping-limit) can use the [:scope](https://www.w3.org/TR/selectors-4/#scope-pseudo) pseudo-class to require a specific relationship to the [scoping root](https://www.w3.org/TR/selectors-4/#scoping-root):
> ```css
> /* .content is only a limit when it is a direct child of the :scope */
> @scope (.media-object) to (:scope > .content) { ... }
> ```
> [Scoping limits](https://www.w3.org/TR/2021/WD-css-cascade-6-20211221/#scoping-limit) can also reference elements outside their [scoping root](https://www.w3.org/TR/selectors-4/#scoping-root) by using [:scope](https://www.w3.org/TR/selectors-4/#scope-pseudo). For example:
> ```css
> /* .content is only a limit when the :scope is inside .sidebar */
> @scope (.media-object) to (.sidebar :scope .content) { ... }
> ```
The scoping proposal is mostly focussed on component based styling.
I think the weak scoping proximity feature that is part of the scoping proposal would also be useful for sibling selectors. I was not sure if this was also covered by the current specification.
`Example 3` seems to allow room for a scope with this definition :
```css
@scope (.media-object) to (:scope ~ .text-object) { ... }
```
---------
### Example :
Styling any paragraph elements that follow a certain heading element.
```css
h1 ~ p {
color: red;
}
h2 ~ p {
color: green;
}
h3 ~ p {
color: blue;
}
```
```html
<h1>Main heading (h1)</h1>
<p>Red text</p>
<h2>Sub heading (h2)</h2>
<p>Green text</p>
<p>Green text</p>
<h3>Smaller heading (h3)</h3>
<p>Blue text</p>
<p>Blue text</p>
<h2>Sub heading (h2)</h2>
<p>Blue text, but intended green</p>
<p>Blue text, but intended green</p>
```
<img width="322" alt="Screenshot of example HTML and CSS described above showing how the general sibling selector in CSS also does not account for element proximity." src="https://user-images.githubusercontent.com/11521496/165245715-0a2815b7-a064-41c1-9b32-a0e7f20e6ce5.png">
Possibly we can write this CSS :
```css
@scope (h1) to (:scope ~ :is(h1, h2, h3, h4, h5, h6)) {
p {
color: red;
}
}
@scope (h2) to (:scope ~ :is(h1, h2, h3, h4, h5, h6)) {
p {
color: green;
}
}
@scope (h3) to (:scope ~ :is(h1, h2, h3, h4, h5, h6)) {
p {
color: blue;
}
}
```
Please view or discuss this issue at https://github.com/w3c/csswg-drafts/issues/7233 using your GitHub account
--
Sent via github-notify-ml as configured in https://github.com/w3c/github-notify-ml-config
Received on Tuesday, 26 April 2022 07:44:24 UTC