首页 > 解决方案 > 就伪元素而言,如何编写模块化 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-colorpadding声明。

现在假设,出于某种原因,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规则集中。

这个代码复制有什么干净的方法吗?

标签: htmlcsscss-selectorspseudo-elementreusability

解决方案


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>


推荐阅读