CSS scroll-padding-top 属性
定义和用法
scroll-padding-top 属性指定从容器顶部到子元素吸附位置的距离。
吸附位置是指在停止滚动时,子元素在容器中吸附到位的位置。
吸附位置由 scroll-snap-align 属性设置,但也可能受到 CSS 属性 direction 和 writing-mode 的影响。
注意:此属性仅在吸附位置设置在子元素顶部时有效。
要看到 scroll-padding-top 属性的效果,必须在子元素上设置 scroll-snap-align 属性,并在父元素上设置 scroll-padding-top 和 scroll-snap-type 属性。
实例
例子 1
将滚动内边距设置为从容器顶部到吸附位置的距离为 20px:
div {
scroll-padding-top: 20px;
}
例子 2:图片库
scroll-padding-top 属性可用于具有吸附行为的图片画廊,以将图片推到固定元素下方:
#container {
scroll-padding-top: 30px;
}
例子 3:在顶部设置滚动内边距
当在两个方向上都设置了吸附行为时,也可以在容器上设置 scroll-padding-top 属性。垂直滚动到下一个元素以查看效果:
#container {
scroll-padding-top: 30px;
}
例子 4:吸附位置
要使 scroll-padding-top 属性生效,吸附位置必须设置在子元素的顶部。在此示例中,writing-mode 属性将吸附位置从子元素的顶部更改为右侧。使用这样的代码时,scroll-padding-top 属性将不再起作用:
#container {
writing-mode: vertical-rl;
scroll-padding-top: 30px;
}
#container > div {
scroll-snap-align: start none;
}
CSS 语法
scroll-padding-top: auto|value|initial|inherit;
属性值
| 值 | 描述 |
|---|---|
| auto | 默认值。浏览器计算内边距。 |
| length |
以 px、pt、cm 等单位指定 scroll-padding-top。 不允许使用负值。请参阅:CSS 单位。 |
| % | 指定包含元素宽度的百分比作为内边距。 |
| initial | 将此属性设置为其默认值。参阅 initial。 |
| inherit | 从其父元素继承此属性。参阅 inherit。 |
技术细节
| 默认值: | auto |
|---|---|
| 继承性: | 否 |
| 动画制作: | 不支持。请参阅:动画相关属性。 |
| 版本: | CSS3 |
| JavaScript 语法: | object.style.scrollPaddingTop="20px" |
浏览器支持
表格中的数字表示首个完全支持该属性的浏览器版本。
| Chrome | Edge | Firefox | Safari | Opera |
|---|---|---|---|---|
| 69.0 | 79.0 | 68.0 | 14.1 | 56.0 |