
本文介绍如何利用纯CSS,基于元素索引,实现元素颜色按n%3模式循环交替的效果。这种技术在创建视觉上吸引人的列表或网格布局时非常有用。
假设我们有以下HTML结构:
<div class="container">
<p></p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/cb6835dc7db1" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">前端免费学习笔记(深入)</a>”;</p>
<div class="aritcle_card">
<a class="aritcle_card_img" href="/ai/appmall%E5%BA%94%E7%94%A8%E5%95%86%E5%BA%97">
<img src="https://img.php.cn/upload/ai_manual/000/000/000/175679968212304.png" alt="AppMall应用商店">
</a>
<div class="aritcle_card_info">
<a href="/ai/appmall%E5%BA%94%E7%94%A8%E5%95%86%E5%BA%97">AppMall应用商店</a>
<p>AI应用商店,提供即时交付、按需付费的人工智能应用服务</p>
<div class="">
<img src="/static/images/card_xiazai.png" alt="AppMall应用商店">
<span>56</span>
</div>
</div>
<a href="/ai/appmall%E5%BA%94%E7%94%A8%E5%95%86%E5%BA%97" class="aritcle_card_btn">
<span>查看详情</span>
<img src="/static/images/cardxiayige-3.png" alt="AppMall应用商店">
</a>
</div>
<p></p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/cb6835dc7db1" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">前端免费学习笔记(深入)</a>”;</p>
<p></p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/cb6835dc7db1" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">前端免费学习笔记(深入)</a>”;</p>
<p></p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/cb6835dc7db1" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">前端免费学习笔记(深入)</a>”;</p>
<p></p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/cb6835dc7db1" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">前端免费学习笔记(深入)</a>”;</p>
<p></p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/cb6835dc7db1" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">前端免费学习笔记(深入)</a>”;</p>
</div>以及CSS变量定义:
.container {
--color1: #fff;
--color2: #da3838;
--color3: rgb(49, 196, 23);
p {
/* 其他样式 */
}
}我们的目标是让每个<p></p>元素的背景颜色按照n%3的余数循环变化:
--color1
--color2
--color3
--color1
CSS的nth-child伪类可以实现这一目标。通过巧妙地运用nth-child的语法,我们可以选择特定的元素并应用不同的样式。
解决方案:
.container p:nth-child(3n+1) {
background-color: var(--color1);
}
.container p:nth-child(3n+2) {
background-color: var(--color2);
}
.container p:nth-child(3n+3) {
background-color: var(--color3);
}这段CSS代码利用了nth-child(3n+x)选择器:
3n+1 选择所有索引除以3余数为1的元素 (1, 4, 7, ...)3n+2 选择所有索引除以3余数为2的元素 (2, 5, 8, ...)3n+3 选择所有索引除以3余数为0的元素 (3, 6, 9, ...)通过以上CSS代码,我们成功地实现了<p></p>元素背景颜色的循环交替效果,满足了n%3的模式要求。 这种方法简洁高效,完全使用纯CSS实现,避免了JavaScript的额外开销。
以上就是如何使用纯CSS实现元素颜色按n%3模式交替的效果?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号