Select a pseudo-element's "owner" (css nesting)

Hey! I just wanted to know, when nested in some pseudo-elements rule, is it possible to access its "owner" (select #owner:hover::after when in #owner::after, for instance)? That's more a question about CSS than a problem, I'm just curious.
17 Replies
Wolle
Wolle15mo ago
Maybe with :has(::after)?
Zpiboo
ZpibooOP15mo ago
It doesn't work, actually I don't think it's possible
clevermissfox
clevermissfox15mo ago
I think I’ve seen on a KP video that you can’t select that way at least in scss if I remember right.
Zpiboo
ZpibooOP14mo ago
Guess I'd just stick with that then
#element {
&::after {
/* Styles */
}
&:hover::after {
/* Styles for when #element is hovered */
}
}
#element {
&::after {
/* Styles */
}
&:hover::after {
/* Styles for when #element is hovered */
}
}
I'm waiting till tomorrow to mark this as solved, just in case
MarkBoots
MarkBoots14mo ago
yea, this is the way. can't get out of a nest looking up
Zpiboo
ZpibooOP14mo ago
If it were just a direct child of the #element, :hover > & would've worked, I was wondering if there was a way to do that with pseudo-elements, but coming up with that wasn't a problem
MarkBoots
MarkBoots14mo ago
yea, i know, but with pseudo's unfortunatly not
Zpiboo
ZpibooOP14mo ago
Anyway thank y'all guys Yea
MarkBoots
MarkBoots14mo ago
good luck
Zpiboo
ZpibooOP14mo ago
Should I close the post?
Jochem
Jochem14mo ago
just add the solved tag
Zpiboo
ZpibooOP14mo ago
Okay
ἔρως
ἔρως14mo ago
are you working with css or sass/scss? if you're working with scss, it's actually possible to do what you want however, i VERY STRONGLY recommend that you do not do it, as the code becomes a convoluted mess an alternative could be to do this:
#element {
&::after {
/* styles */
}

&:hover {
/* styles for when #element is hovered */
&::after {
/* styles for the ::after when #element is hovered */
}
}
}
#element {
&::after {
/* styles */
}

&:hover {
/* styles for when #element is hovered */
&::after {
/* styles for the ::after when #element is hovered */
}
}
}
i do use the selectors like this, but only when i have styles to apply to :hover, which you often do this way, you can also easily re-use the :hover to, for example, style a child element, like this:
#element {
&:hover {
&::after { ... }
svg { ... }
}
}
#element {
&:hover {
&::after { ... }
svg { ... }
}
}
and if someone says "butt muh 80 chars colms", i will roll my eyes as 80 columns of text hasnt been a problem since 1280x1080 was invented (just don't over-do it)
Zpiboo
ZpibooOP14mo ago
I never used scss, and again I was just curious about it being possible. Anyway, thanks for the answers :D
ἔρως
ἔρως14mo ago
the examples i gave also work in css
Zpiboo
ZpibooOP14mo ago
What? I thought you were saying there was a really hacky or just "bad" way to do it in scss (directly nested in #element::after), and that you just preferred to give an alternative in css xd
ἔρως
ἔρως14mo ago
yes, but i didn't share that cursed horrible thing here

Did you find this page helpful?