是否可以使用CSS或Sass将样式应用于锚点的所有伪选择器?
例如:
a:* {
color: #900;
}
代替
a {
&:hover, &:link, &:active, &:visited {
color: #900;
}
}
我只想重置标准样式。在CSS中,通配符可以用于将样式应用于所有元素...但是如何应用于所有伪选择器?是否可以使用CSS或Sass将样式应用于锚点的所有伪选择器?
例如:
a:* {
color: #900;
}
代替
a {
&:hover, &:link, &:active, &:visited {
color: #900;
}
}
我只想重置标准样式。在CSS中,通配符可以用于将样式应用于所有元素...但是如何应用于所有伪选择器?简短回答: 不可以直接实现
然而,可以使用mixin来达到类似的效果。
// Sets the style only for pseudo selectors
@mixin setLinkSelectorStyle {
&:hover, &:link, &:active, &:visited {
@content;
}
}
// Sets the style to pseudo selectors AND base default anchor
@mixin setLinkStyleAll {
&, &:hover, &:link, &:active, &:visited {
@content;
}
}
a {
color:red;
@include setLinkSelectorStyle {
color:gold;
}
}
a.specialLink {
@include setLinkStyleAll {
color:purple;
}
}
[Example using http://sassmeister.com/ compiled SASS]
a {
color: red;
}
a:hover, a:link, a:active, a:visited {
color: gold;
}
a.specialLink, a.specialLink:hover, a.specialLink:link, a.specialLink:active, a.specialLink:visited {
color: purple;
}
<a>Normal anchor, No href (:link won't work, but other selectors will)</a>
<hr />
<a href="#">Normal anchor</a>
<hr />
<a class="specialLink">Specific class (no href)</a>
<hr />
<a class="specialLink" href="#">Specific class</a>
U can do it like that:
&:before, &:after {
content: 'a';
}