简介
在本实验中,我们将探索 CSS 编程的基础知识。通过一系列实践练习和项目,你将学习如何为 HTML 内容设置样式、操控布局和定位,以及创建能适应不同屏幕尺寸的响应式设计。在本实验结束时,你将拥有扎实的 CSS 基础,并能够创建出视觉效果惊艳的网页。
这是一个实验(Guided Lab),提供逐步指导来帮助你学习和实践。请仔细按照说明完成每个步骤,获得实际操作经验。根据历史数据,这是一个 初级 级别的实验,完成率为 89%。获得了学习者 100% 的好评率。
This tutorial is from open-source community. Access the source code
💡 本教程由 AI 辅助翻译自英文原版。如需查看原文,您可以 切换至英文原版
在本实验中,我们将探索 CSS 编程的基础知识。通过一系列实践练习和项目,你将学习如何为 HTML 内容设置样式、操控布局和定位,以及创建能适应不同屏幕尺寸的响应式设计。在本实验结束时,你将拥有扎实的 CSS 基础,并能够创建出视觉效果惊艳的网页。
虚拟机中已经提供了 index.html
和 style.css
。
要创建一个响应式图像拼接效果,使用 display: grid
来创建一个响应式网格布局,设置 grid-template-columns: repeat(auto-fit, minmax(240px, 1fr))
和 grid-auto-rows: 240px
。要让项目跨越两行或两列,使用 grid-row: span 2 / auto
和 grid-column: span 2 / auto
。最后,将这些样式包装在一个媒体查询中,以避免在小屏幕尺寸上应用它们。
<div class="image-mosaic">
<div
class="card card-tall card-wide"
style="background-image: url('https://picsum.photos/id/564/1200/800')"
></div>
<div
class="card card-tall"
style="background-image: url('https://picsum.photos/id/566/800/530')"
></div>
<div
class="card"
style="background-image: url('https://picsum.photos/id/575/800/530')"
></div>
<div
class="card"
style="background-image: url('https://picsum.photos/id/626/800/530')"
></div>
<div
class="card"
style="background-image: url('https://picsum.photos/id/667/800/530')"
></div>
<div
class="card"
style="background-image: url('https://picsum.photos/id/678/800/530')"
></div>
<div
class="card card-wide"
style="background-image: url('https://picsum.photos/id/695/800/530')"
></div>
<div
class="card"
style="background-image: url('https://picsum.photos/id/683/800/530')"
></div>
<div
class="card"
style="background-image: url('https://picsum.photos/id/693/800/530')"
></div>
<div
class="card"
style="background-image: url('https://picsum.photos/id/715/800/530')"
></div>
<div
class="card"
style="background-image: url('https://picsum.photos/id/610/800/530')"
></div>
<div
class="card"
style="background-image: url('https://picsum.photos/id/599/800/530')"
></div>
</div>
.image-mosaic {
display: grid;
gap: 1rem;
grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
grid-auto-rows: 240px;
}
.card {
display: flex;
justify-content: center;
align-items: center;
background: #353535 url("https://picsum.photos/id/564/1200/800") center /
cover no-repeat;
font-size: 3rem;
color: #fff;
box-shadow:
rgba(3, 8, 20, 0.1) 0px 0.15rem 0.5rem,
rgba(2, 8, 20, 0.1) 0px 0.075rem 0.175rem;
height: 100%;
width: 100%;
border-radius: 4px;
transition: all 500ms;
overflow: hidden;
padding: 0;
margin: 0;
}
.card-tall {
grid-row: span 2 / auto;
}
.card-wide {
grid-column: span 2 / auto;
}
@media screen and (max-width: 599px) {
.card-tall,
.card-wide {
grid-row: span 1 / auto;
grid-column: span 1 / auto;
}
}
请点击右下角的“Go Live”以在端口 8080 上运行网络服务。然后,你可以刷新“Web 8080”标签页来预览网页。
恭喜你!你已经完成了响应式图像拼接实验。你可以在 LabEx 中练习更多实验来提升你的技能。