就伪元素而言,如何编写模块化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-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
声明从它内部赞成在 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>
假设按照设计,所有元素都应该看起来像具有给定颜色并带有一些阴影的图块;是这样的:
.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
声明从它内部赞成在 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>