<!DOCTYPE html>
<html>
<head>
<style>
#container {
width: 80%;
aspect-ratio: 3/1;
padding: 40px 0;
margin: auto;
border: solid black 2px;
overflow-x: hidden;
overflow-y: scroll;
scroll-snap-type: y mandatory;
scroll-padding: 20px;
}
.blue {
background-color: lightblue;
width: 95%;
aspect-ratio: 3/1;
}
.green {
background-color: lightgreen;
width: 80%;
aspect-ratio: 4/1;
}
.blue, .green {
margin: 2px;
scroll-snap-align: start;
}
</style>
</head>
<body>
<h1>CSS scroll-padding 属性</h1>
<p>scroll-padding 属性设置在容器上,以便子元素的吸附位置与容器之间有一个偏移距离。</p>
<p>在此情况下,吸附位置设置为在 y 方向上开始,因此焦点元素应该吸附到容器的最顶部。但由于 scroll-padding 值的设置,焦点元素与容器之间有了 20px 的内边距偏移。</p>
<div id="container">
<div class="blue"></div>
<div class="green"></div>
<div class="blue"></div>
<div class="green"></div>
<div class="blue"></div>
<div class="green"></div>
<div class="blue"></div>
</div>
</body>
</html>