就伪元素而言,如何编写模块化CSS?

How to write modular CSS as far as pseudo-elements are concerned?

假设按照设计,所有元素都应该看起来像具有给定颜色并带有一些阴影的图块;是这样的:

.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 声明从它内部赞成在 HTML 中添加 class="down-right-box-shadow",因为 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>