html - 就伪元素而言,如何编写模块化 CSS?
问题描述
假设按照设计,所有元素都应该看起来像给定颜色的瓷砖并带有一些阴影;像这样的东西:
.panel {
background-color: #bbffff;
padding: 1em;
box-shadow: 0.5em 0.5em 0.5em 0em rgba(0,0,0,50%);
}
<div class="panel">
Some text
</div>
在这一点上,考虑编写模块化 CSS,我已经很想选择box-shadow
声明并将其放入自己的规则集中,
.down-right-box-shadow {
box-shadow: 0.5em 0.5em 0.5em 0em rgba(0,0,0,50%);
}
这样我就可以通过添加class="down-right-box-shadow"
到 HTML 标记来重用它,而无需引入background-color
和padding
声明。
现在假设,出于某种原因,CSS 使用伪元素来创建靠近这些图块的一些效果,如下所示:
.panel {
background-color: #bbffff;
padding: 1em;
display: flex;
flex-direction: column;
align-items: center;
margin-bottom: 0.4em;
}
.down-right-box-shadow {
box-shadow: 0.5em 0.5em 0.5em 0em rgba(0,0,0,50%);
}
.panel::after {
content: "";
width: 1em;
height: 1em;
border-radius: 100%;
margin-top: 0.2em;
background-color: blue;
box-shadow: 0.5em 0.5em 0.5em 0em rgba(0,0,0,50%);
}
<div class="panel down-right-box-shadow">
Some text
</div>
显然,其意图是::after
伪元素与页面上的其他所有元素具有相同的阴影,但由于它是伪元素,因此我无法box-shadow
从其中删除声明以支持添加class="down-right-box-shadow"
HTML,因为没有元素在它的 HTML 中。
所以我必须.down-right-box-shadow
至少在这两个地方重写相同的声明。
如果明天.down-right-box-shadow
规则集中的某些内容发生变化,我必须记住将相同的更改应用到.panel::after
规则集中。
这个代码复制有什么干净的方法吗?
解决方案
Temani Afif 有道理。使用变量:
:root {
--down-right-box-shadow: 0.5em 0.5em 0.5em 0em rgba(0,0,0,50%);
}
.panel {
background-color: #bbffff;
padding: 1em;
display: flex;
flex-direction: column;
align-items: center;
margin-bottom: 0.4em;
}
.down-right-box-shadow {
box-shadow: var(--down-right-box-shadow);
}
.panel::after {
content: "";
width: 1em;
height: 1em;
border-radius: 100%;
margin-top: 0.2em;
background-color: blue;
box-shadow: var(--down-right-box-shadow);
}
<div class="panel down-right-box-shadow">
Some text
</div>
我可能遗漏了一些东西,但这也应该有效:
.down-right-box-shadow,
.panel.down-right-box-shadow::after {
box-shadow: 0.5em 0.5em 0.5em 0em rgba(0,0,0,50%);
}
当然,您必须添加多个选择器,以防您想要其他不是的元素.panel
,但它解决了多个box-shadow
问题
.panel {
background-color: #bbffff;
padding: 1em;
display: flex;
flex-direction: column;
align-items: center;
margin-bottom: 0.4em;
}
.down-right-box-shadow,
.panel.down-right-box-shadow::after {
box-shadow: 0.5em 0.5em 0.5em 0em rgba(0,0,0,50%);
}
.panel::after {
content: "";
width: 1em;
height: 1em;
border-radius: 100%;
margin-top: 0.2em;
background-color: blue;
}
<div class="panel down-right-box-shadow">
Some text
</div>
推荐阅读
- c - 声明外部堆栈时出现预期声明说明符错误
- javascript - 如何将选定的复选框推送到对象数组中?
- java - 这是 Jackson JsonParser 中的错误,还是我做错了什么?
- javascript - How do I make use of await and async in this function?
- html - How to modify the styles of the values of the radio buttons in CSS?
- spring-boot - Transaction silently rolled back because it has been marked as rollback-only
- python - Graphite pickle protocol: what is the maximum message size?
- apache-kafka - where is max.partition.fetch.bytes value in kafka consumer?
- javascript - HTML: Input type date and range of months
- python - matplotlib 和阶乘函数